diff --git a/.gitignore b/.gitignore
index ed3fb7a..5aa699f 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,6 +1,2 @@
-*.zip
-*.ZIP
-*.Zip
-*.clang-format
-*cmake-build-debug
-*.idea
+# Ignore
+*.zip
\ No newline at end of file
diff --git a/Exam/IKT203Exam/.gitignore b/Exam/IKT203Exam/.gitignore
new file mode 100644
index 0000000..5057ecf
--- /dev/null
+++ b/Exam/IKT203Exam/.gitignore
@@ -0,0 +1,5 @@
+# Ignore Visual Studio cache
+.vs/
+
+# Ignore build/output directory
+out/
\ No newline at end of file
diff --git a/Exam/IKT203Exam/.idea/.gitignore b/Exam/IKT203Exam/.idea/.gitignore
new file mode 100644
index 0000000..13566b8
--- /dev/null
+++ b/Exam/IKT203Exam/.idea/.gitignore
@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/Exam/IKT203Exam/.idea/.name b/Exam/IKT203Exam/.idea/.name
new file mode 100644
index 0000000..b50dd3f
--- /dev/null
+++ b/Exam/IKT203Exam/.idea/.name
@@ -0,0 +1 @@
+IKT203_Course_Assignments
\ No newline at end of file
diff --git a/assignment1/.idea/assignment1.iml b/Exam/IKT203Exam/.idea/IKT203-main.iml
similarity index 100%
rename from assignment1/.idea/assignment1.iml
rename to Exam/IKT203Exam/.idea/IKT203-main.iml
diff --git a/assignment1/.idea/editor.xml b/Exam/IKT203Exam/.idea/editor.xml
similarity index 100%
rename from assignment1/.idea/editor.xml
rename to Exam/IKT203Exam/.idea/editor.xml
diff --git a/Exam/IKT203Exam/.idea/material_theme_project_new.xml b/Exam/IKT203Exam/.idea/material_theme_project_new.xml
new file mode 100644
index 0000000..554b701
--- /dev/null
+++ b/Exam/IKT203Exam/.idea/material_theme_project_new.xml
@@ -0,0 +1,12 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/assignment1/.idea/misc.xml b/Exam/IKT203Exam/.idea/misc.xml
similarity index 100%
rename from assignment1/.idea/misc.xml
rename to Exam/IKT203Exam/.idea/misc.xml
diff --git a/assignment1/.idea/modules.xml b/Exam/IKT203Exam/.idea/modules.xml
similarity index 57%
rename from assignment1/.idea/modules.xml
rename to Exam/IKT203Exam/.idea/modules.xml
index 8a1cdd1..290b5dd 100644
--- a/assignment1/.idea/modules.xml
+++ b/Exam/IKT203Exam/.idea/modules.xml
@@ -2,7 +2,7 @@
-
+
\ No newline at end of file
diff --git a/Exam/IKT203Exam/.idea/vcs.xml b/Exam/IKT203Exam/.idea/vcs.xml
new file mode 100644
index 0000000..b2bdec2
--- /dev/null
+++ b/Exam/IKT203Exam/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/Exam/IKT203Exam/CMakeLists.txt b/Exam/IKT203Exam/CMakeLists.txt
new file mode 100644
index 0000000..b77f5a3
--- /dev/null
+++ b/Exam/IKT203Exam/CMakeLists.txt
@@ -0,0 +1,26 @@
+# Set the minimum version of CMake required to build this project.
+# This ensures that older versions of CMake don't try to run with features they don't understand.
+cmake_minimum_required(VERSION 3.20)
+
+# Define the project name. This will be the top-level name in Visual Studio.
+# It also enables the C++ language (CXX).
+project(IKT203_Course_Assignments LANGUAGES CXX)
+
+# We enforce C++17 (or C++20 if you prefer) for the entire project.
+# All targets (exercises, libraries, etc.) will inherit this setting.
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+set(CMAKE_CXX_EXTENSIONS OFF)
+
+if(MSVC)
+ add_compile_options("/Zc:__cplusplus")
+endif()
+
+# This is the core of the orchestration. CMake will now step into each of these
+# folders and process their own CMakeLists.txt files.
+# The order matters here: we add LibExample first so that its library is
+# defined before the executables that need to link to it.
+
+add_subdirectory(Portfolio)
+
+# --- End of File ---
\ No newline at end of file
diff --git a/Exam/IKT203Exam/CMakePresets.json b/Exam/IKT203Exam/CMakePresets.json
new file mode 100644
index 0000000..b57aba8
--- /dev/null
+++ b/Exam/IKT203Exam/CMakePresets.json
@@ -0,0 +1,61 @@
+{
+ "version": 3,
+ "configurePresets": [
+ {
+ "name": "windows-base",
+ "hidden": true,
+ "generator": "Visual Studio 17 2022",
+ "binaryDir": "${sourceDir}/out/build/${presetName}",
+ "installDir": "${sourceDir}/out/install/${presetName}",
+ "cacheVariables": {
+ "CMAKE_C_COMPILER": "cl.exe",
+ "CMAKE_CXX_COMPILER": "cl.exe"
+ },
+ "condition": {
+ "type": "equals",
+ "lhs": "${hostSystemName}",
+ "rhs": "Windows"
+ }
+ },
+ {
+ "name": "x64-debug",
+ "displayName": "x64 Debug",
+ "inherits": "windows-base",
+ "architecture": {
+ "value": "x64",
+ "strategy": "external"
+ },
+ "cacheVariables": {
+ "CMAKE_BUILD_TYPE": "Debug"
+ }
+ },
+ {
+ "name": "x64-release",
+ "displayName": "x64 Release",
+ "inherits": "x64-debug",
+ "cacheVariables": {
+ "CMAKE_BUILD_TYPE": "Release"
+ }
+ },
+ {
+ "name": "x86-debug",
+ "displayName": "x86 Debug",
+ "inherits": "windows-base",
+ "architecture": {
+ "value": "x86",
+ "strategy": "external"
+ },
+ "cacheVariables": {
+ "CMAKE_BUILD_TYPE": "Debug"
+ }
+ },
+ {
+ "name": "x86-release",
+ "displayName": "x86 Release",
+ "inherits": "x86-debug",
+ "cacheVariables": {
+ "CMAKE_BUILD_TYPE": "Release"
+ }
+ }
+ ]
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/DATA/city_graph.txt b/Exam/IKT203Exam/DATA/city_graph.txt
new file mode 100644
index 0000000..405307b
--- /dev/null
+++ b/Exam/IKT203Exam/DATA/city_graph.txt
@@ -0,0 +1,37 @@
+[NODES;records:=9]
+Oslo
+Bergen
+Trondheim
+Stavanger
+Kristiansand
+Ålesund
+Molde
+Bodø
+Tromsø
+[EDGES;records:=26]
+Oslo;Bergen;450
+Bergen;Oslo;460
+Oslo;Trondheim;820
+Trondheim;Oslo;790
+Oslo;Stavanger;600
+Stavanger;Oslo;650
+Bergen;Stavanger;210
+Stavanger;Bergen;190
+Bergen;Trondheim;540
+Trondheim;Bergen;520
+Trondheim;Ålesund;220
+Ålesund;Trondheim;240
+Ålesund;Bergen;310
+Bergen;Ålesund;300
+Stavanger;Kristiansand;180
+Kristiansand;Stavanger;170
+Kristiansand;Oslo;400
+Oslo;Kristiansand;410
+Trondheim;Bodø;600
+Bodø;Trondheim;620
+Bodø;Tromsø;500
+Tromsø;Bodø;480
+Ålesund;Molde;130
+Molde;Ålesund;120
+Molde;Trondheim;260
+Trondheim;Molde;250
\ No newline at end of file
diff --git a/Exam/IKT203Exam/DATA/network_graph.txt b/Exam/IKT203Exam/DATA/network_graph.txt
new file mode 100644
index 0000000..e47be45
--- /dev/null
+++ b/Exam/IKT203Exam/DATA/network_graph.txt
@@ -0,0 +1,29 @@
+[NODES;records:=11]
+WebServer
+Router1
+AuthService
+CacheServer
+Database
+APIGateway
+LoadBalancer
+Firewall
+AnalyticsServer
+BackupServer
+FileServer
+[EDGES;records:=16]
+WebServer;Router1;4
+WebServer;AuthService;8
+WebServer;CacheServer;5
+Router1;Database;3
+Router1;LoadBalancer;2
+Router1;Firewall;7
+AuthService;Database;2
+AuthService;APIGateway;6
+CacheServer;LoadBalancer;4
+CacheServer;FileServer;3
+FileServer;BackupServer;9
+Database;AnalyticsServer;5
+APIGateway;AnalyticsServer;4
+LoadBalancer;Firewall;3
+Firewall;BackupServer;8
+AnalyticsServer;BackupServer;7
\ No newline at end of file
diff --git a/Exam/IKT203Exam/DATA/random_names.txt b/Exam/IKT203Exam/DATA/random_names.txt
new file mode 100644
index 0000000..deb18fd
--- /dev/null
+++ b/Exam/IKT203Exam/DATA/random_names.txt
@@ -0,0 +1,5401 @@
+[records:=5400]
+Adryan Mandel
+Rayah Steinke
+Jay Villa
+Nisa Laskowski
+Zarya Gerry
+Aster Lammers
+Jacquelyn Escamilla
+Jayden Walker
+Adna Klassen
+Vita Mcelhaney
+Ibrahim Brandt
+Warren Case
+Alasia Wargo
+Maris Hallock
+Khaliyah Evangelista
+Edson Sackett
+Saria Beech
+Braysen Krieg
+Conner Lindsey
+Dora Glynn
+Blake Gould
+Reyaan Kulp
+Celestine Sala
+Breya Woodside
+Abdurrahman Charbonneau
+Terry Holbrook
+Dalary Coyle
+Leigh Cotten
+Caitlyn Magana
+Cecilia Manning
+Aubriana Altman
+Cleveland Parmenter
+Gurleen Hagans
+Ahri Gillett
+Kepler Ohalloran
+Sailor Bey
+Elvira Nickell
+Emileigh Eichelberger
+Isaac Ramirez
+Allyanna Swinford
+Carolynn Mincey
+Keylan Schreck
+Ayelen Darr
+Stephon Armendariz
+Analee Pond
+Emmeline Cartwright
+Onyx Shuster
+Dinah Strait
+Hasan Vergara
+Kaisyn Dehoyos
+Shaylyn Glasser
+Yetzali Moynihan
+Azaan Loredo
+Riaan Conroy
+Damani Caesar
+Domenic Cockrell
+Rey Coe
+Malaki Whitmore
+Kaitlynn Osorio
+Lavell Brogdon
+Jaeda Deane
+Nirvan Broadus
+Lennox Mckinley
+Fernando Stokes
+Lynnix Peart
+Alize Zayas
+Mariely Harshbarger
+Shmuel Guillory
+Alahna Roos
+Silvano Preece
+Gia Barr
+Reeva Heine
+Lilliann Hazlett
+Jadiel Colbert
+Jayde Winston
+Marigold Rutkowski
+Jessi Durden
+Marina Tang
+Charlene Pence
+Audra Meehan
+Keeva Litchfield
+Lulu Prasad
+Kaliah Delvalle
+Charley Ives
+Ziyon Watterson
+Scottlyn Lazarus
+Demetrius Schmitz
+Abella Rudy
+Sarenity Moorer
+Jewel Hurd
+Cassia Wampler
+Zaedyn Witcher
+Aariana Baskerville
+Golden Grinnell
+Kaito Skeen
+Braydin Schuh
+Kynlee Gregg
+Jaice Knecht
+Zayna Rausch
+Anastazia Nealy
+Tevita Janik
+Joanne Perea
+Anabia Yowell
+Neely Depalma
+Codi Rubenstein
+Sora Behnke
+Kamryn Fair
+Ronan Baxter
+Damiya Egbert
+Qusai Clymer
+Katiana Mosely
+Harleigh Busch
+Beaux Correia
+Felipe Engle
+Evelina Tharp
+Anabelle Crews
+Selene Joiner
+Lucianna Sisco
+Krista Bunn
+Elwood Lippert
+Aubreigh Fabian
+Rania Mcwhorter
+Kaylan Abram
+Karianna Bridwell
+Stassi Marcos
+Dartagnan Morano
+Braxtyn Comstock
+Tyree Boston
+Kavin Hernandes
+Jaelle Trigg
+Braylen Valentine
+Emersen Kiel
+Devontae Sylvia
+Kim Mckeown
+Mataya Mager
+Saxon Hinz
+Henson Cowden
+Yara Call
+Reeve Viramontes
+Clarke Duck
+Evalynn Hirsch
+Lennox Mckinley
+Alajah Gaughan
+Aston Elam
+Zamara Laguna
+Subhan Harner
+Ellagrace Kale
+Godric Damian
+Jansen Swaim
+Maverick Vaughn
+Tillie Saxon
+Colston Battaglia
+Rylan Urban
+Summer Todd
+Mekhai Alessi
+Zaylah Durr
+Ahtziri Nilsen
+Bernadette Burden
+Irvin Minter
+Jianna Chapin
+Arman Hoyle
+Brayton Beeler
+Sahir Furtado
+Kayleigh Stephenson
+Layken Harbison
+Remington Dempsey
+Kaesyn Fessler
+Avan Hack
+Sky Hendrick
+Mariam Hendrickson
+Tommie Sansone
+Avry Pavlik
+Beckett Rodgers
+Myron Whitson
+Kilian Edge
+Phillip Shah
+Tidus Brasher
+Raider Landin
+Taggart Dryer
+Dakota Olsen
+Britton Blythe
+Cristian Lamb
+Xoe Binion
+Vinh Casiano
+Arien Chafin
+Valente Brigman
+Tylor Bly
+Elani Jurado
+TRUE Theriot
+Jaceon Oreilly
+Delila Fee
+Kathy Branson
+Aviona Lines
+Malika Urias
+Yasser Polley
+Karin Laux
+Nakai Crossman
+Zion Campos
+Kaylah Bruns
+Rohan Lord
+Jacori Hiner
+Trinity Ortega
+Reniyah Bengtson
+Eniyah Mazzola
+Anwar Collette
+Molly Schwartz
+Nile Schick
+Jackie Martz
+Maisyn Roa
+Story Mckenney
+Johnpaul Brinson
+Aivah Blaisdell
+Coleson Montez
+Wren Bloom
+Giorgio Minnick
+Tailynn Wash
+Aleeyah Staten
+Naia Sander
+Terrance Burrell
+Kinsler Schweizer
+Lori Chiu
+Jeter Molloy
+Carmyn Beaman
+Gretel Mickey
+Holly Odom
+Leandre Deen
+Cloud Gehrke
+Aaliyah Castillo
+Atharva Groom
+Jeziah Mouser
+Kayanna Silvas
+Brenleigh Kirkham
+Kent Covarrubias
+Azariah Gabriel
+Siana Shiver
+Tidus Brasher
+Lilliann Hazlett
+Suleiman Zak
+Taylor Daniels
+Marshawn Ellington
+Rosalyn Jansen
+Natasha Ziegler
+Gwen Kimball
+Adela Bartley
+Maxson Mckoy
+Christopher Mitchell
+Farah Chapa
+Zev Barrientos
+Shaye Sweatt
+Kodi Shirey
+Briel Mcquade
+Kaydence Lefevre
+Anny Marty
+Divine Bounds
+Amoura Mauk
+Trinitee Costanzo
+Alahni Bickham
+Adira Salem
+Anahi Locke
+Stacey Derrick
+Mason Galbraith
+Guadalupe Kidder
+Yashvi Waldner
+Janey Thurber
+Jariah Partida
+Royce Dale
+Rooney Michelson
+Gabe Joe
+Gillian Zhu
+Alba Condon
+Stephania Ton
+Amilliana Windle
+Jalena Saez
+Olympia Oxford
+Charleston Pelletier
+Nora Cole
+Genessis Dominick
+Amelia Campbell
+Leylanie Gutierres
+Savanah Zheng
+Conway Thurmond
+Ashton Austin
+Shrihan Alvis
+Jean Jeter
+Kristel Merz
+Shelby Kissel
+Aarohi Belt
+Candice Searcy
+Breelynn Warnock
+Lyndon Orman
+Emberlynn Mcduffie
+Emi Augustine
+Brayden Sullivan
+Payzlee Hower
+Amethyst Herzog
+Duke Burks
+Carlyn Eder
+Pamela Troyer
+Ramsey Nunes
+Amarii Hessle
+Jagger Butts
+Syriah Breton
+Denise Cope
+Essa Vannoy
+Siddhartha Gish
+Kalleigh Sandstrom
+Gene Luis
+Sonora Curcio
+Solana Tyner
+Remie Mui
+Kage Hard
+Amina Cline
+Daxx Leitch
+Jayquan Straw
+Parisa Vineyard
+Rainey Min
+Ziona Baugher
+Franki Gulick
+Jomar Chartier
+Ailani Dowell
+Brooklin Heiser
+Tanya Israel
+Laniyah Barbour
+Kashius Brisco
+Avyan Byerly
+Josalyn Moats
+Korben Legg
+Ariza Keffer
+Terron Alleyne
+Leni Kennard
+Deisy Bolduc
+Dontay Pera
+Esther Saunders
+Patton Place
+Maddyn Musselman
+Haddon Brashear
+Jasir Aronson
+Gwyneth Stringer
+Nala Shipley
+Tevita Janik
+Nayah Jaques
+Miking Ciccone
+Parks Juan
+Jovian Billington
+Winifred Garber
+Tennyson Erskine
+Talon Rossi
+Graeson Sabin
+Jeziah Mouser
+Rico Ragan
+Arielle Lester
+Kepler Ohalloran
+Yandel Fanning
+Mahala Sias
+Sadie Freeman
+Tilly Montiel
+Bosco Lieb
+Tallon Stotts
+Marley Patton
+Arjun Shoemaker
+Tristin Duggins
+Matix Dalessandro
+Van Dickens
+Arleth Gaytan
+Cartier Ehlers
+Atticus Orozco
+Auden Gilmer
+Korbyn Ashmore
+Gabby Deming
+Kaeden Baron
+Reyli Karns
+Cristian Lamb
+Santos Woodson
+Finley Camacho
+Lyric Olivares
+Katalina Beaver
+Ella Cooper
+Megan Dorsey
+Shakira Boardman
+Saxon Hinz
+Mai Kahl
+Erielle Pasley
+Kynadee Gorrell
+Josemanuel Palmore
+Rosaleigh Bedard
+Hank Farris
+Rachelle Robinette
+Evalyn Caballero
+Yuri Teel
+Lindley Dear
+Amellia Monzon
+Novah Chronister
+Tate Cisneros
+Miah Rodrigues
+Yusuf Madison
+Evianna Bushnell
+Aidyn Shiflett
+Evelynn Rubio
+Hadrian Rosenblatt
+Shaquille Pardue
+Koltin Miceli
+Addison James
+Destiney Rubino
+Rivers Dameron
+Jedidiah Bunch
+Embree Chisolm
+Haroon Abbey
+Arius Dvorak
+Jusiah Cranston
+Vega Jump
+Jillian Blanchard
+Josemanuel Palmore
+Ashley Hudson
+Soleil Cohn
+Kalyn Tello
+Rickey Tennant
+Briseis Stamps
+Hubert Coen
+Charissa Dice
+Gabby Deming
+Parth Gottlieb
+Tylee Meacham
+Meliah Barriga
+Jeancarlo Mcanally
+Adalynne Heckman
+Ilias Elswick
+Gretta Raya
+Jean Rosenberger
+Jaliyah Leal
+Anibal Annis
+Christy Weidner
+Maylani Whyte
+Ellamae Proulx
+Noora Rager
+Jaciel Weeden
+Niklas Bennington
+Minna Barto
+Cayden Dennis
+Kyan Mcarthur
+Kate Hartman
+Naomy Mather
+Shaina Archibald
+Serenity Schmidt
+Kabir Devries
+Milan Moses
+Brielle Bates
+Arron Arango
+Coraline Hewitt
+Bayne Hillis
+Kalvin Batista
+Jazmine Stuart
+Xzander Bemis
+Eira Borchardt
+Alyssandra Nestor
+Damani Flora
+Yeray Dull
+Keanna Crotty
+Caspian Shull
+Jamison Kaufman
+Maddilynn Puentes
+Keller Millard
+Morghan Fudge
+Zenaida Huckaby
+Juniper Lynn
+Frieda Barcia
+Robert Ortiz
+Brianne Basile
+Aamina Twomey
+Marjorie Geiger
+Ina Bixler
+Gohan Cavallaro
+Donatello Winkle
+Chauncey Tankersley
+Aris Carraway
+Juliet Aguirre
+Alexavier Millan
+Madina Carmack
+Matilyn Barley
+Kasper Risner
+Finley Camacho
+Kathia Krupa
+Maelee Chew
+Kaedyn Kimber
+Ysabella Trombley
+Adia Pleasant
+Jaclyn Babb
+Arnoldo Edmundson
+Corwin Wingard
+Maximino Linehan
+Kiana Stacy
+Liara Yip
+Cal Hite
+Cayla Medlin
+Abbi Kania
+Jozlynn Woolfolk
+Keisi Duron
+Kassidee Lathan
+Aj Plante
+Alahna Roos
+Aisley Royster
+Laila Luna
+Anvitha Wirtz
+Rooney Michelson
+Easton Hammock
+Teegan Laney
+Zade Faison
+Zofia Viola
+Kaidance Nilsson
+Cache Maynor
+Glen Gerard
+Addilynn Hollingsworth
+Arsema Chitwood
+Raisa Tims
+Gunther Costanza
+Navy Caputo
+Pearl Webber
+Taylar Pegram
+Violeta Perdue
+Milania Dodge
+Quin Rubalcava
+Jailee Criss
+Eviana Echeverria
+Blythe Ceja
+Riana Mellott
+Blue Bigler
+Trinity Ortega
+Zacarias Ignacio
+Yulianna Dugas
+Avrohom Greiner
+Payslee Breland
+Kiah Dumont
+Kendrix Eberhart
+Dianne Lundeen
+Nataleigh Sacco
+Jaslene Ashe
+Jiana Guan
+Servando Confer
+Keysha Howze
+Krish Lind
+Keisy Munger
+Tiffani Quijada
+Kensington Ogden
+Aili Sartin
+Talyn Avendano
+Katherin Burgin
+Anika Cash
+Armaan Scarborough
+Callee Foxworth
+Zamara Laguna
+Jenika Elson
+Drew Corey
+Baileigh Hamblin
+Josalynn Shope
+Leelah Gilmartin
+Jefferson Cordero
+Koral Dunson
+Braylin Martines
+Darian Fedor
+Asiyah Ballesteros
+Jamar Loomis
+Naisha Paulk
+Nihira Spiller
+Dakota Olsen
+Katara Peet
+Crispin Rhee
+Arav Robey
+Emiliano Hodges
+Mackenzie Plowman
+Deborah Bower
+Waleed Arreguin
+Robin Busby
+Aida Escalante
+Joey Alcantar
+Hezekiah Poe
+Rivka Schaffer
+Dustyn Manor
+Myasia Esqueda
+Mick Hoss
+Salomon Farber
+Rhea Leung
+Kelcie Quimby
+Marcelino Whitworth
+Saya Turney
+Arabella Sherman
+Elouise Behrens
+Denisse Matson
+Samanta Applewhite
+Medina Tart
+Mihir Willie
+Jaydee Pillow
+Mikaylah Deas
+Dominick Vincent
+Deklen Lafond
+Lennon Stinson
+Mohamedamin Ruddy
+Dirk Delcastillo
+Alaa Gilpin
+Ivana Ryder
+Heather Spaulding
+Abdurrahman Charbonneau
+Jaren Luster
+Zuleyka Benavidez
+Kansas Mcadoo
+Kirah Nottingham
+Masen Rincon
+Bridgette Luu
+Shaniya Marx
+Daemon Hollinger
+Spirit Marrone
+Soledad Seng
+Jolee Maas
+Arlo Craft
+Mahogany Rupert
+Jadore Quillen
+Rithvik Walczak
+Clementine Huggins
+Halley Wight
+Kevon Schnell
+Ambria Laurie
+Huxley Dowling
+Kinlee Barrow
+Lillyan Denham
+Jeffery Fonseca
+Lamya Metzler
+Aulani Pennell
+Johnson Graziano
+Mohamed Spence
+Dany Rondeau
+Avani Falcon
+Jaylyn Barkley
+Meir Greenfield
+Aaliyah Castillo
+Dmitri Casto
+Jaceion Houk
+Aric Rounds
+Alize Zayas
+Hallee Braithwaite
+Broderick Lytle
+Pranav Switzer
+Isabelle Watkins
+Ansel Main
+Fallyn Nemeth
+Adhvik Jacinto
+Mei Cashman
+Courtland Haworth
+Tzipora Lacombe
+Quinn Roach
+Zayden Warner
+Bradleigh Karim
+Aiden Conyers
+Aleenah Householder
+Jess Gallimore
+Halo Fortune
+Hero Chevalier
+Ianna Wilds
+Analiyah Buxton
+Crawford Doane
+Noelia Forte
+Lawrence Workman
+Kiarah Humbert
+Emonie Anson
+Keon Halverson
+Ellora Fan
+Kerrington Benally
+Blaine Elkins
+Kiya Lieberman
+Sammy Brockman
+Maddex Hackney
+Annie Macias
+Addilyn Zamora
+Kathrine Poor
+Shulem Pagel
+Kassie Taber
+Pryce Santoyo
+Rebeka Mickle
+Precious Cao
+Sahar Manriquez
+Maryanna Turek
+Bella Ryan
+Kaiden Dalrymple
+Kamilla Lewandowski
+Hailee Browne
+Maple Fazio
+Kameryn Penaloza
+Frederick Mackey
+Aviva Gaither
+Virginia Mcgowan
+Tayah Laurent
+Aleksey Brewton
+Darion Reiss
+Abubakr Cantor
+Emerald Conn
+Elexis Roseberry
+Amarachi Barwick
+Rory Mora
+Alonah Hurwitz
+Abbie Horvath
+Elena Dean
+Abel Lawrence
+Christiano Hollander
+Aldo Cho
+Eiza Laster
+Tyquan Therrien
+Sari Fregoso
+Audriana Eason
+Auri Sanfilippo
+Luqman Palomares
+Rhiannon Hardwick
+Kelsey Huang
+Caeli Cai
+Aubreanna Leboeuf
+Yajaira Kantor
+Kamryn Escobar
+Anyssa Carlo
+Jahmari Sterner
+Tomas Piper
+Margeaux Campuzano
+Amador Balogh
+Addyson Horne
+Demarius Endres
+Yaritza Lujan
+Kemari Barros
+Lane Beattie
+Lamar Wyrick
+Ashten Orth
+Jensen Lavender
+Carmela Motley
+Amaya Frank
+Quinn Munoz
+Lakai Chauvin
+Manav Brannen
+Akshara Mesa
+Jasiyah Stalnaker
+Hershy Swick
+Mirabella Mccleary
+Deangelo Hutson
+Sanvi Boss
+Muriel Northern
+Avi Betancourt
+Samantha West
+Quincy Herrick
+Remmy Boyette
+Alba Condon
+Shyann Curiel
+Shayaan Bunton
+Sharif Vankirk
+Amauri Lindell
+Keaton Varghese
+Keturah Gervais
+Kristin Partridge
+Remington Huff
+Brenleigh Kirkham
+Samar Rembert
+Kemora Castelli
+Jenesis Arnett
+Tillman Revels
+Jack Morris
+Abdulrahman Valdivia
+Brienne Weise
+Alyah Hollowell
+Ameen Nester
+Brooklin Heiser
+Leilanie Wrenn
+Kyara Newland
+Ozzy He
+Odalis Kisner
+Gina Jauregui
+Damoni Camper
+Kai Varela
+Skilar Camden
+Kacey Starnes
+Safiyyah Beckford
+Hadley Jensen
+Jaxen Schafer
+Mahir Hollenbeck
+Salina Sawyers
+Addelynn Lathrop
+Kolbi Doster
+Amor Corrales
+Markeith Mathewson
+Don Carbone
+Jackie Martz
+Susana Withers
+Kynzleigh Newlin
+Marlen Burd
+Annaly Lambrecht
+Zeena Maiden
+Taylor Daniels
+Quin Dahlberg
+Aisha Andersen
+Nazir Andrus
+Eshan Siebert
+Tiffany Archer
+Jurgen Elia
+Simona Lett
+Lilah Hutchinson
+Camari Gosnell
+Garret Anton
+Genessis Dominick
+Journee Sexton
+Delayza Basso
+Janey Thurber
+Christelle Kimura
+Mea Christopherson
+Abbigail Jung
+Aunna Gregorio
+Evah Escoto
+Lisandro Chi
+Georgina Wyman
+Arshiya Laliberte
+Raquel Self
+Grant Frazier
+Deanthony Judy
+Kenzlie Cawley
+Mariama Hensel
+Maura Frias
+Bobbi Lavigne
+Malachai Bent
+Anastasiya Millen
+Tenzin Bogan
+Aeden Littrell
+Adalin Templin
+Reagan Bynum
+Danni Ridenour
+Kaydee Vanmeter
+Katelyn Lang
+Lamarcus Mccafferty
+Severin Spoon
+Eli Wood
+Ravenna Cripe
+Kayleen Trahan
+Rozalyn Cauthen
+Carmyn Beaman
+Yovani Jordon
+Hashir Dufour
+Danielle Valencia
+Jaziah Mckeever
+Zamarion Busse
+Kynley Wiener
+Jaliah Brenneman
+Chevelle Beckett
+Imani Odell
+Loyal Olmos
+Faigy Soares
+Suzanne Cromwell
+June Jefferson
+Kaliah Delvalle
+Paisleigh Marrero
+Starla Gragg
+Kipton Lundberg
+Elizabeth Carter
+Paxton Wolf
+Breasia Mcmillin
+Alajah Gaughan
+Anish Leong
+Calan Blackstone
+Devora Roeder
+Caine Santacruz
+Mariana Dalton
+Cheyenne Prince
+Prince Mcfarland
+Bensen Saravia
+Samora Delucia
+Walid Knepper
+Leopold Strain
+Nayeli Novak
+Clarke Macpherson
+Milly Wimberly
+Catelynn Thoms
+Yvette Clancy
+Brady Reeves
+Hiram Fugate
+Raylan Riddle
+Jahiem Resnick
+Rubin Cespedes
+Tiger Husband
+Kavon Matta
+Klaus Litton
+Caysen Moe
+Alanis Reinhardt
+Kaeson Crossley
+Estrella Goins
+Elian Saucedo
+Laynie Hitt
+Aundrea Neese
+Kalaya Mcclary
+Jalynn Resendez
+Kaiyah Matteson
+Ilaria Morman
+Jeremyah Grau
+Ellen Yarbrough
+Xavior Wacker
+Wayne Han
+Delanie Herrmann
+Ace Bean
+Mazie Wilde
+Zamira Hixson
+Karson Rivas
+Holden Clayton
+Javontae Otten
+Eliab Slavin
+Jovan Martino
+Laksh Ruch
+Edie Kinder
+Ahlam Benham
+Talen Valentino
+Jax Alvarenga
+Monika Fick
+Kharter Isaacson
+Cassia Wampler
+Sage Bartlett
+Ani Olguin
+Aleina Harr
+Kaysen Aguilera
+Maiyah Ensley
+Elyzabeth Heatherly
+Tanvi Sanborn
+Zamiyah Yarborough
+Shaelyn Wilhite
+Aeris Vickery
+Judson Benedict
+Eve Rowland
+Jacey Seaman
+Makena Begay
+Breonna Smitherman
+Aicha Braddock
+Therese Baskin
+Brodie Delatorre
+Eveline Knuth
+Pinchas Gilles
+Zena Edens
+Aizah Giese
+Wayland Blades
+Blanca Lindberg
+Titus Meyers
+Elara Durkee
+Ellah Mumford
+Seren Studer
+Lariah Bunnell
+Lamarion Seeger
+Rianna Tseng
+Saharsh Scheid
+Tevita Janik
+Lily Reyes
+Shianne Hersey
+Saw Earp
+Vanya Willman
+Ines Fairbanks
+Lucinda Bertrand
+Fatema Perrotta
+Allie Serrano
+Cameron Costello
+Masyn Paulino
+Meila Edelman
+Emsley Sasser
+Cotton Stiffler
+Keasia Aho
+Siobhan Phillip
+Alekzander Baeza
+Rigoberto Handley
+Jayceon Ballard
+Laurel Maher
+Braven Folk
+Rawan Murchison
+Martez Ledoux
+Kaia Hayden
+August Erickson
+Aissatou Weathersby
+Mandy Mcdougal
+Kale Moya
+Deacon Baird
+Hadlee Coates
+Bernard Robert
+Gloriana Drews
+Tariah Fowlkes
+Barrett Allison
+Mackson Pitchford
+Nico Downs
+Inez Wessel
+Yohanna Propst
+Avril Levesque
+Janely Mcmichael
+Jourdyn Tennyson
+Rhema Giddings
+Ren Vuong
+Niko Schumacher
+Falynn Caruthers
+Ruston Sealey
+Kierstyn Mach
+Tenley Vo
+Jaselle Darlington
+Chole Buckman
+Zakai Leger
+Henderson Basinger
+Erma Strode
+Adalind Frame
+Ellyson Massengale
+Japheth Massaro
+Shifra Flake
+Jaicee Fuhrman
+Harris Seals
+Oshea Volz
+Kirill Garretson
+Evy Spitzer
+Amauri Broome
+Aura Kaye
+Jaylan Mcdaniels
+Yatziry Bowler
+Deetya Driskill
+Charleston Pelletier
+Suzette Mcgriff
+Evren Swink
+Dakarai Mccandless
+Genaro Felts
+Eugenia Korte
+Laykin Moline
+Macee Deering
+Mackynzie Carleton
+Tennessee Lebrun
+Aaliya Heilman
+Aylee Shults
+Taylor Mercer
+Axyl Broadnax
+Nayely Thach
+Xander Hardy
+Vernon Ramon
+Marlo Blessing
+Bently Harkins
+Eddie Hagen
+Ranger Angle
+Semaj Paschal
+Rodolfo Ennis
+Annalyn Pogue
+Amara Maddox
+Tanish Carcamo
+Shriya Gorski
+Florence Sepulveda
+Samia Zhao
+Jireh Banker
+Herschel Frechette
+Angelika Beckner
+Teresa Manley
+Atziri Vereen
+Janice Tinsley
+Brailyn Sturgis
+Arie Staggs
+Yaqub Rosier
+Ely Mehta
+Rania Mcwhorter
+Raigan Obregon
+Tamiyah Pigg
+Guiliana Fetter
+Cambria Haywood
+Clarice Eicher
+Lyon Carrell
+Amen Chestnut
+Jordin Neri
+Shelbie Albarran
+Bransyn Glazer
+Arlett Hazard
+Charley Dejesus
+Caius Selby
+Yazan Lawless
+Angelynn Geiser
+Jarell Delano
+Landyn Madden
+Rosalyn Jansen
+Anwita Deville
+Kaine Brownlee
+Ivie Towns
+Adilynn Siegel
+Zayed Fitz
+Aris Blanchette
+Katheryne Dimartino
+Malka Winslow
+Madison Beale
+Tegan Aguayo
+Ena Wortham
+Dino Rusk
+Kennadie Trainer
+Rosa Pike
+Donte Wing
+Queenie Delia
+Eastyn Valente
+Khaleesi Steward
+Kofi Canas
+Ellyana Spooner
+Darrius Easterling
+Bradley Lowe
+Kyree Perron
+Damario Hermes
+Hollis Mcclelland
+Ryla Doud
+Kaylen Catlett
+Jeziah Mouser
+Nahomy Woodley
+Alec Zavala
+Kyaire Kahle
+Cailyn Salcedo
+Theophilus Teasley
+Jeronimo Council
+Adel Welty
+Nyla Andrade
+Hera Russel
+Mirel Kost
+Chaz Poston
+Yuritzi Carstens
+Jayliah Sluder
+Abriel Lemos
+Stanley Rainey
+Nestor Skidmore
+Kristal Barthel
+Jeb Blackford
+Deen Welton
+Sabina Loy
+Delia Grubb
+Eric Lynch
+Cassius Funk
+Tali Falco
+Isac Escalera
+Buck Caviness
+Reign Purvis
+Zamari Packer
+Teagen Ivie
+Adelaida Adrian
+Talib Urbano
+Yasmina Abell
+Armoni Crooks
+Rilee Custer
+Kira Whitehead
+Octavio Mayberry
+Dilynn Rinker
+Brooks Gill
+Presten Posner
+Shanell Persinger
+Batya Colangelo
+Kalea Lusk
+Saina Woodland
+Brexton Fortney
+Calli Roller
+Evan Putman
+Cierra Mauldin
+Haydon Worthen
+Debora Fogarty
+Emanuel Beasley
+Kenan Halstead
+Daleyza Marsh
+Ellery Friend
+Alexzandria Vanhoose
+Alahni Bickham
+Koen German
+Eleonora Brownfield
+Drea Steelman
+Jairus Schreiner
+Hajar Mcbeth
+Sahir Furtado
+Grayden Argueta
+Adelyn Avila
+Marquise Cason
+Ty Bolton
+Taelor Haught
+Briel Mcquade
+Demian Nicely
+Jasir Aronson
+Tyree Boston
+Kailer Cottrill
+Daniella Wiley
+Keanu Prieto
+Robyn Crowell
+Katalyna Guadarrama
+Colin Nunez
+Brylan Bischoff
+Keagen Niemeyer
+Lorelei Richmond
+Jayven Noriega
+Aylin Kerr
+Ayana Zimmer
+Jaxon Cook
+Creed Roush
+Kaliyah Espinosa
+Brigid Allman
+Blakelyn Enright
+Claudio Laing
+Roselynn Kwon
+Truly Kerrigan
+Zariah Vang
+Rowdy Troutman
+Karter Field
+Mayah Loyd
+Krew Mattox
+Malena Martins
+Galilea Crabtree
+Kayceon Hoelscher
+Annamaria Beaudry
+Kiera Avalos
+Nate Villareal
+Katharine Infante
+Elizaveta Donoghue
+Calise Congdon
+Lucia Clarke
+Talin Mcentire
+Valen Vermillion
+Laikyn Dover
+Jentry Siu
+Auston Delvecchio
+Dakoda Lavin
+Maci Randall
+Alma Gore
+Gibran Bevins
+Ashby Coll
+Lisandra Holsinger
+Lailah Crouch
+Arsen Wrobel
+Coy Benner
+Dyani Stanfill
+Bryelle Scalf
+Chantal Ruppert
+Kallen Nadeau
+Rowynn Reader
+Paradise Meadors
+Emori Bahena
+Braelee Coots
+Milana Baca
+Nelson Shapiro
+Luci Weiler
+Rayce Joshi
+Arsh Gilroy
+Brice Rosenthal
+Demar Spradley
+Sanjay Rosser
+Menno Tressler
+Kyrie Sawyer
+Gabriella Snyder
+Colter Beverly
+Damarius Suazo
+Raymond Pham
+Galen Cotto
+Saori Malin
+Jed Serrato
+Fern Rau
+Adolfo Montanez
+Emeli Esteban
+Olan Mong
+Aubrielle Sprague
+Akshaya Breault
+Airam Arneson
+Baruch Nowell
+Lander Caudillo
+Salome Noe
+Karlos Copenhaver
+Adelina Crowley
+Raleigh Schubert
+Sylas Dewitt
+Jariyah Donato
+Brody Gardner
+Donavon Saltzman
+Ivyana Pendley
+Keyla Purcell
+Sundus Blakey
+Felicity Stein
+Madison Nelson
+Brendon Chau
+Brilee Nation
+Mckinlee Hefner
+Aurelio Eads
+Georgie Granillo
+Makiah Cowley
+Maelyn Packard
+Elijah Martin
+Angelia Peltier
+Nelly Morey
+Burke Cowell
+Jacorey Siddiqui
+Vanesa Settles
+Abram Howe
+Kellyn Du
+Noa Raley
+Jadon Schwab
+Neve Forney
+Beatrix Anders
+Lovina Mansell
+Layth Pete
+Johann Lyman
+Timber Wortman
+Antwone Trimmer
+Joann Godoy
+Fateh Eddington
+Avyana Sly
+Gabriela Mckenzie
+Faye Levin
+Scotty Arrowood
+Abdulmalik Izquierdo
+Rolando Ham
+Bladen Cofield
+Raizy Kohn
+Canon Heinrich
+Azaliah Hardaway
+Azalia Koss
+Reese Clifford
+Lucienne Billy
+Sara Ball
+Melissa Summers
+Dalila Bull
+Martin Burnett
+Zavian Spellman
+Elynn Galli
+Joe Esquivel
+Shylah Banta
+Khadija Strauss
+Amare Adair
+Jasen Kocher
+Raider Landin
+Elliott Oconnor
+Afia Masi
+Coltan Vaillancourt
+Aedan Mcnulty
+Sommer Dann
+Parks Juan
+Audra Meehan
+Roisin Soukup
+Maleny Janis
+Theseus Colombo
+Edgardo Hunsaker
+Jewell Cleaver
+Tatum Pineda
+Kadrian Ismail
+Rosy Chowdhury
+Royce Dale
+Malorie Leake
+John King
+Lakshmi Fleenor
+Edmond Monaghan
+Lavinia Prior
+Kristiana Mckelvey
+Dhilan Walcott
+Dartagnan Morano
+Mischa Lafrance
+Yetzali Moynihan
+Sailor Doran
+Uma Underhill
+Maite Blackman
+Tristen Elmore
+Getsemani Faith
+Bill Bakken
+Levi Blaine
+Greyson Pirtle
+Kaylynn Crow
+Arayah Fiore
+Wyatt Evans
+Micaiah Farrington
+Nikayla Ottinger
+Lelia Yamada
+Zeus Valerio
+Demarco Covert
+Jarrett Bearden
+Cypress Kain
+Kamaria Dombrowski
+Arrianna Lalonde
+Isabell Durbin
+Estefany Cecil
+Sidra Beltz
+Leeam Perna
+Nechama Grantham
+Yolanda Gagne
+Barbie Sheaffer
+Kamya Volpe
+Armand Herd
+Layten Maria
+Alexandre Garnett
+Ruth Garrison
+Emran Kwak
+Aking Maney
+Mariangel Charron
+Sheila Kuntz
+Billy Dietz
+Mavis Wilkes
+Rylin Czarnecki
+Charlene Pence
+Aadyn Bakke
+Adyn Wyant
+Dexter Arroyo
+Geneva Hayward
+Demiyah Spradling
+Landri Loveland
+Leighton Daugherty
+Azalea Whitfield
+Naila Holly
+Kendall Cabral
+Austen Malik
+Avyaan Manns
+Payzlee Hower
+Korah Keil
+Laynee Porterfield
+Aya Tripp
+Logann Wheelock
+Lee Featherstone
+Tobin Banda
+Gryffin Rodman
+Andy Gudino
+Nakai Crossman
+Arlin Mcgaha
+Maison Rhoades
+Ali Glenn
+Suzanne Cromwell
+Ailynn Burkhalter
+Tyanna Word
+Danilo Julian
+Rashaad Carreno
+Samar Hazelwood
+Whitlee Kile
+Javontae Otten
+Emarie Gaddy
+Maryam Bacon
+Ailee Hilbert
+Wilmer Monroy
+Pepper Cooney
+Gryffin Rodman
+Robin Christie
+Oak Hayashi
+Jonny Rue
+Betsy Bethea
+Caston Gravely
+Makaio Forester
+Shiloh Saenz
+Livvy Braley
+Praise Hibbert
+Alessio Gilligan
+Jayanna Lattimore
+Syriah Breton
+Jazmin Ashley
+Claude Conners
+Nora Cole
+Zabdiel Mullens
+Karaline Souder
+Keyana Rimmer
+Valentina Reid
+Solomon Calhoun
+Journey Philips
+Ameenah Surber
+Arianny Dinh
+Lillyann Alves
+Abdirahman Centeno
+Ashlyn Clay
+Collin Trujillo
+Dutch Chipman
+Nayah Jaques
+Cai Fitzhugh
+Jamal Irvin
+Marwan Gandhi
+Josalyn Moats
+Laine Nall
+Yasmine Burleson
+Asher Mcdonald
+Rockwell Covey
+Musab Winder
+Nicole Bush
+Dulcemaria Frady
+Betzaida Nichol
+Kimberley Hartung
+Adelyn Avila
+Braelynn Dudley
+Naima Schofield
+Atticus Orozco
+Keziah Singletary
+Aleksandra Duenas
+Kaisley Murrell
+Shrey Frederickson
+Fredy Elliot
+Jehu Cabello
+Eloise Wilcox
+Kasandra Alva
+Brinley Walls
+Tavion Billups
+Regina Bonner
+Ryu Freese
+Hazen Elston
+Zayd Worthington
+Alizee Michaelis
+Ruslan Davie
+Talib Urbano
+Rorie Alleman
+Eris Woolsey
+Eren Varga
+Wyland Slaven
+Aurea Gandara
+Jazmyne Jewett
+Mariam Hendrickson
+Mikaila Merriweather
+Aliza Peralta
+Judah Jasinski
+Kinley Yates
+Laiklyn Geraci
+Quincy Vigil
+Zamara Laguna
+Aster Lammers
+Angeli Bonnett
+Jeylin Million
+Cord Kerwin
+Wendell Amin
+Christiana Alley
+Rian Janssen
+Kelsi Batts
+Ada Berger
+Milania Dodge
+Ayaan Curran
+Camelia Tower
+Bryson Guzman
+Reegan Boatman
+Bella Ryan
+Sephora Warrick
+Jalon Newport
+Anastasiya Millen
+Sandra Arrington
+Iziah Jayne
+Seanna Enciso
+Genevie Govea
+Layah Silvers
+Noor Mcneill
+Rivan Tennison
+Amaira Suh
+Garett Seagraves
+Markeith Mathewson
+Sariah Brantley
+Salem Bolin
+Alanis Reinhardt
+Thiago Russo
+Raena Berard
+Riker Koehn
+Demario Doerr
+Booker Humes
+Ariyan Spinner
+Hanah Beckmann
+Anaiah Morley
+Syncere Eliason
+Jaylene Ngo
+Leliana Drumm
+Damiyah Blodgett
+Sapphire Fierro
+Leslie Ta
+Eleen Alfano
+Elouise Behrens
+Ilse Harville
+Josias Archuleta
+Louis Flowers
+Greenlee Bucci
+Ladarius Claudio
+Joseline Mashburn
+Charity Stauffer
+Brooks Ung
+Katana Farkas
+Breasia Mcmillin
+Alizay Oquendo
+Jalen Courtney
+Dalia Munson
+Clifton Abney
+Karly Graf
+Ariannah Johnstone
+Penelope Fisher
+Rhea Leung
+Maddilynn Puentes
+Marcello Stock
+Delanie Herrmann
+Aleesa Kellett
+Jesenia Schade
+Sione Hirst
+Jaxin Rhea
+Garen Garr
+Reef Alt
+Paul Espinoza
+Shepard Samson
+Baylie Kuehn
+Kalia Beavers
+Marley Patton
+Yadiel Nickerson
+Chassidy Lukas
+Able Fussell
+Esai Lozada
+Riana Mellott
+Avalyn Caudill
+Rayshawn Peeler
+Dandre Shorter
+Cloud Gehrke
+Pamela Troyer
+Annamarie Mello
+Alaynah Brumley
+Arwen Mota
+Cheyann Serio
+Caelum Luedtke
+Mason Miller
+Khylee Bricker
+Malique Lovelady
+Madden Nicol
+Ariana Alvarez
+Amilah Board
+Naksh Stringfellow
+Quinn Roach
+Lee Crockett
+Miabella Parent
+Stormy Snowden
+Surah Oboyle
+Thea Stanton
+Jasiah Cassidy
+Georgiana Alicea
+Catalina Ware
+Charbel Clift
+Andie Shank
+Areej Griffen
+Leviathan Abramson
+Rogue Bohl
+Stetson Hackett
+Caleah Hudspeth
+Johannah Merino
+Bayron Kipp
+Brenden Read
+Miliana Pinckney
+Paris Bannister
+Danielle Valencia
+Carsen Bales
+Aleyah Barksdale
+Legend Mulkey
+Evette Peabody
+Dublin Vanlandingham
+Darya Kato
+Jatziry Reiff
+Kinzleigh Lapierre
+Sequoia Nutt
+Andrae Carlock
+Aeris Vickery
+Basya Cavin
+Journii Jessie
+Landyn Madden
+Reese Navarro
+Gillian Zhu
+Evangelina Van
+Adhrit Bergquist
+Devonte Warden
+Bryce Greene
+Anh Stelly
+Nirvana Sanches
+Everley Steffen
+Harold Prater
+Marilynn Quesada
+Tyshaun Hennings
+Jozlyn Goodell
+Hadassah Portillo
+Camille Montoya
+Wayland Blades
+Ellieana Pye
+Brissa Batson
+Haylen Midkiff
+Austen Malik
+Indiana Stidham
+Elyana Dell
+Leonard Griggs
+Ezra Jolly
+Dominique Whitlock
+Carrigan Chairez
+Isamar Witham
+Ahaan Rathbun
+Lynlee Weems
+Kerry Grenier
+Rylan Hampton
+Laksh Ruch
+Fateh Eddington
+Julia Ray
+Gadiel Sachs
+Everett Brazil
+Paisleigh Marrero
+Mattie Cates
+Geovany Faris
+Paxson Lesher
+Denver Ashby
+Cameron Costello
+Hermione Wingfield
+Hugo Nixon
+Paislee Suarez
+Aalyah Collis
+Anjali Felder
+Ansley Nava
+Breelynn Warnock
+Perseus Bartz
+Shmiel Brammer
+Massiah Edmond
+Sophya Landreth
+Lilian Mooney
+Lea Jewell
+Eder Denson
+Acacia Woodworth
+Evelyn Parker
+Demi Quinones
+Denise Cope
+Mckynlee Baldridge
+Teddy Sauceda
+Barbara Samuels
+Emeri Ralston
+Mishika Toner
+Ashleigh Desantis
+Aziza Hagerman
+Clarissa Smart
+Olive Conley
+Janis Leftwich
+Reynaldo Forrester
+Cristian Lamb
+Keagen Niemeyer
+Gonzalo Askew
+Marciano Rana
+Alahni Bickham
+Gracee Stocks
+Anaisha Bevan
+Bawi Holzer
+Jacinta Burkey
+Oaklynn Galan
+Zailee Spohn
+Deonte Griffis
+Jake Cummings
+Lyra Uribe
+Rodney Engel
+Raelee Mackay
+Ellamae Proulx
+Dorothea Lasher
+Said Weed
+Shailene Gunning
+Harbor Lenard
+Jair Sharma
+Rivers Gatewood
+Leobardo Dufresne
+Aj Plante
+Aubrianna Hathaway
+Lucie Asher
+Laiken Grillo
+Dontavious Pecoraro
+Tavian Roberto
+Evalyn Caballero
+Mahalia Gregor
+Linken Melgoza
+Castle Giardina
+Ariany Linderman
+Rosie Egan
+Lucero Noll
+Kamdon Avitia
+Adleigh Free
+Erion Tilson
+Kalina Quinlan
+Kaiden Salazar
+Naia Sander
+Onyx Shuster
+Hawthorne Brick
+Domenick Poss
+Harper Kilgore
+Wylder Paddock
+Ranya Pickle
+Ashton Austin
+Davonte Boling
+Raleigh Schubert
+Athena Dawson
+Teagen Ivie
+Silver Luevano
+Alizabeth Sass
+Woodrow Hung
+Ellis Diehl
+Ambrielle Rainer
+Jaselle Darlington
+Jeremih Kroll
+Summer Todd
+Kadynce Cargill
+Arabella Sherman
+Kullen Montana
+Jaeden Seeley
+Bralynn Dehaven
+Bryan Wade
+Soha Woolf
+Xitlali Nolen
+Kahlia Abrahamson
+Eugenia Korte
+Timmy Cozart
+Johana Cable
+Kenna Roe
+Adya Romer
+Lawson Church
+Lela Lemons
+Ailin Roybal
+Kyan Mcarthur
+Chanelle Yamamoto
+Barry Farnsworth
+Sunni Marinelli
+Wednesday Dollar
+Jalaysia Polite
+Maddilyn Harry
+Hadeel Hoeft
+Avyana Sly
+Joely Cardinal
+Deonta Thrift
+Brynnley Armour
+Azura Blackmore
+Zanaya Quesenberry
+Keiry Nino
+Zyler Shen
+Amire Tullis
+Zahara Cheney
+Kelsy Drown
+Rima Moncrief
+Raylin Orosco
+Demond Harness
+Davina Willoughby
+Malinda Vanwinkle
+Irvin Minter
+Samaya Flannery
+Slate Gallup
+Maleyah Cothran
+Elizabeth Carter
+Quran Cortese
+Leonardo Medina
+Kaysen Aguilera
+Elliotte Newhouse
+Skyleigh Coelho
+Zakai Leger
+Vianna Deangelo
+Zack Nobles
+Maddyson Oliphant
+Corbyn High
+Sol Dancy
+Rayann Aman
+Tristyn Ballinger
+Zarek Shanklin
+Jayson Raymond
+Marshawn Ellington
+Viyan Priester
+Nisa Laskowski
+Adonias Kleinman
+Shayan Everson
+Rubi Upton
+Geronimo Conant
+Maverik Rumsey
+Avarie Hussain
+Kyana Boughton
+Kavon Matta
+Kaylan Abram
+Chanell Coney
+Abdullahi Stinnett
+Katharine Infante
+Conrad Lott
+Niah Upshaw
+Kellie Kephart
+Leander Pichardo
+Michel Bierman
+Dakota Olsen
+Kelia Nauman
+Jacklyn Breedlove
+Susannah Earnest
+Arham Gulley
+Kaleesi Mcmurry
+Eliah Schutz
+Kc Meltzer
+Maxx Ferrer
+Alliana Drain
+Finnian Stockton
+Avyan Byerly
+Demarco Covert
+Conor Cooley
+Jaylen Blackwell
+Allisyn Ruano
+Sanai Casper
+Graci Ascencio
+Hollis Mcclelland
+Anaiya Echevarria
+Ellasyn Haviland
+Alonna Seal
+Ozzie Islam
+Santhiago Jim
+Lynnlee Buell
+Manny Michels
+Keana Salmons
+Mendel Savoy
+Chelsea Dillon
+Kasey Currie
+Noel Lowery
+Keanna Crotty
+Addison Witherspoon
+Kasyn Eden
+Destiny Potter
+Lux Thigpen
+Eh Rettig
+Zamir Farrar
+Maryn Martel
+Jamire Mauricio
+Kamarion Forsyth
+Svea Brann
+Stellan Wofford
+Shayleigh Dimarco
+Kaci Ricci
+Milagro Yarnell
+Aaric Wagers
+Zaid Otero
+Azul Jameson
+Efren Poirier
+Bladen Cofield
+Ahsan Falconer
+Harun Flatt
+Ayana Zimmer
+Isela Smothers
+Kassandra Newsome
+Kamren Dupree
+Jeffrey Carey
+Krish Lind
+Cheyanne Lockett
+Jared Gilmore
+Allyson Conway
+Ricki Bessette
+Gwen Kimball
+Jeyden Burbank
+Ashtyn Damon
+Carly Glass
+Edy Boaz
+Azlan Walk
+Smith Amato
+Sky Stratton
+Cyrus Gay
+Armando Meza
+Jafet Woodbury
+Niall Tyrrell
+Blakelyn Enright
+Kenadi Musgrove
+Haniya Gammon
+Quinton Gustafson
+Jaedyn Eagle
+Star Ibrahim
+Mika Lander
+Logen Shih
+Amran Phares
+Eduardo Tyler
+Erma Strode
+Khole Scribner
+Nadine Myrick
+Berkley Atwood
+Anabelle Crews
+Iva Tafoya
+Aubriella Mansfield
+Camari Maley
+Newton Alderete
+Meira Sellars
+Nabiha Duquette
+Odette Sandlin
+Alisha Street
+Galen Cotto
+Ivyanna Schiavone
+Hollie Clem
+Mariajose Sutter
+Samirah Hesse
+Deklen Lafond
+Aditi Thiel
+Gerardo Sampson
+Maia Goldberg
+Dasha Hofmann
+Adriana Curry
+Gia Barr
+Jakari Bigelow
+Alaa Gilpin
+Marquise Cason
+Mihir Willie
+Armon Northcutt
+Brycen Petty
+Ellington Horst
+Alfredo Grace
+Loki Zeller
+Ivaan Garnica
+Jayven Noriega
+Carnell Braud
+Kamora Christman
+Monty Korn
+Casen Dubois
+Heston Plant
+Ariona Haskin
+Ziyon Watterson
+Brooklyn Morales
+Abraham Powers
+Hania Oxley
+Zaryah Stultz
+Shekinah Hulett
+Diamond Anaya
+Akai Hedge
+Sylis Weil
+Rajveer Trawick
+Maleena Carbaugh
+Creed Roush
+Melody Lyons
+Avin Kerley
+Elly Zambrano
+Khari Johansen
+Solange Findlay
+Abdulrahman Valdivia
+Carolina Benton
+Jaycee Mccants
+Brock Bray
+Kaiah Pisano
+Dejah Maddux
+Dion Yoon
+Queen Hamrick
+Leeroy Jardine
+Carla Souza
+Addison James
+Navy Conlin
+Abbigale Zito
+Tyra Friday
+Diana Heath
+Zaedyn Witcher
+Kinleigh Irving
+Yoselyn Rascon
+Jazlin Demaria
+Lennon Goff
+Teegan Griego
+Robbie Mackie
+Ivey Ashworth
+Axl Mcmullen
+Micaiah Albano
+Leighton Daugherty
+Karlie Winn
+Archie Easter
+Brigette Kautz
+Keeley Musser
+Airam Arneson
+Clive Rivero
+Blythe Ceja
+Irena Hoard
+Maris Hallock
+Drew Corey
+Kevon Schnell
+Marilyn Herring
+Juaquin Borrero
+Corbin Garner
+Lamonte Vaden
+Kacee Blas
+Howard Reaves
+Salih Hocker
+Yehoshua To
+Carson Foss
+Anyssa Carlo
+Aminata Forster
+Miguel Sandoval
+Luther Mcnutt
+Aren Dyke
+Reginald Shultz
+Juliette Gibbs
+Regan Quan
+Edgar Wyatt
+Fernando Stokes
+Leelan Kinser
+Ayelet Dowdell
+Broderick Lytle
+Adriel Short
+Dequan Pawlowski
+Zakaria Zielinski
+Rosalyn Jansen
+Alisa Keen
+River Villanueva
+Jacklynn Radcliff
+Marygrace Huhn
+Nylah Bernard
+Jacquelin Toms
+Darek Jumper
+Dottie Tyndall
+Jaylanie Azevedo
+Tyrell Lawton
+Araceli Allred
+Bryer Mclemore
+Aviva Gaither
+Karsten Bussey
+Evren Swink
+Indira Markey
+Sirena Hom
+Fausto Mingo
+Kierra Fontaine
+Hailee Browne
+Axell Culler
+Fidel Popp
+Jamyla Runkle
+Ria Southerland
+Eowyn Jessup
+Jetta Arambula
+Danya Atchley
+Karter Watts
+Seneca Blakeney
+Jaqueline Broughton
+Marisol Latham
+Aashna Winton
+Chandler Luke
+Avalynn Toth
+Prisha Masterson
+Lamar Wyrick
+Kenny Champion
+Emelyn Haller
+Eyad Horning
+Maebry Rozier
+Kyrell Pankey
+Adalberto Kerner
+Lake Hagler
+Haven Tanner
+Alasdair Towers
+Tynlee Ruggles
+Griffen Poon
+Hershel Flournoy
+Jewel Hurd
+Shannon Mclain
+Analiyah Buxton
+Jayquan Straw
+Morgan Chappell
+Lenora Harwood
+Sidharth Sokolowski
+Ahri Gillett
+Ellinor Garry
+Kamea Jiles
+Asher Southern
+Odessa Ramsay
+Makenzy Vice
+Collyns Saiz
+Elvis Whitten
+Aniylah Koester
+Laya Demers
+Korbyn Yancey
+Raegan Kirby
+Jaila Homer
+Aaliyah Castillo
+Rashad Marcum
+Adelin Mcgough
+Demetrius Schmitz
+Ashly Brinkman
+Jessia Eidson
+Serafina Ordonez
+Tate Morell
+Amina Cline
+Tito Frawley
+Journie Paxton
+Zyra Hadden
+Lionel Muniz
+Yisrael Jaffe
+Jaedon Treat
+Christopher Mitchell
+Ayala Lower
+Khari Omeara
+Syrus Hildreth
+Eldana Strang
+Haydon Worthen
+Keanu Prieto
+Izzabelle Fetzer
+Jenavieve Catlin
+Elyza Mabe
+Verona Burman
+Ellanor Fenwick
+Andria Benning
+Bodey Danforth
+Phoebe Dickerson
+Delylah Hennessey
+Adilene Lopes
+Kenji Lira
+Edie Kinder
+Maricella Wilken
+Aislynn Wendt
+Korey Kidwell
+Emelia Tyson
+Gina Jauregui
+Rylin Czarnecki
+Edwin Bradford
+Jessica Wise
+Naftali Fielding
+Lizeth New
+Deonna Mulholland
+Kynzie Dore
+Embree Chisolm
+Semaj Paschal
+Race Marini
+Jerzie Lippincott
+Noa Tolbert
+Raul Costa
+Janette Koonce
+Chiamaka Songer
+Kaydence Lefevre
+Ellena Bruton
+Dayana Hatcher
+Tommie Sansone
+Jenesis Arnett
+Xion Wardell
+Aeden Littrell
+Juanita Cady
+Michelangelo Resendiz
+Millie Levine
+Maysen Oman
+Matthew Lopez
+Yaakov Longoria
+Ruhi Tremblay
+Cailee Osman
+Analee Pond
+Tidus Brasher
+Tyler Driver
+Torrance Dinardo
+Arina Ritz
+Maram Willette
+Jaxston Montenegro
+Cheryl Schaub
+Brantly Fried
+Maddelyn Gallego
+Dustyn Manor
+Basma Calle
+Subhan Harner
+Zyla Calkins
+Elia Mahan
+Tegan Mcqueen
+Clinton Wilburn
+Armin Hamer
+Braxtin Lampert
+Bruno Painter
+Allana Ehrlich
+Damoni Camper
+Madilynne Tunstall
+Analyn Shear
+Edith Fulton
+Mylan Riffle
+Olan Mong
+Rihaan Liston
+Antwon Shane
+Ronnie Wilhelm
+Della Coy
+Orrin Bertram
+Porter Baran
+Jessie Ahmed
+Champion Honea
+Vania Bill
+Theia Sledge
+Aharon Lor
+Monika Fick
+Corrine Pilgrim
+Nuha Hartline
+Azriel Mathew
+Joah Dawes
+Nicolle Mclellan
+Stacy Tweedy
+Menno Tressler
+Thaddeus Hammer
+Elleanna Donohoe
+Damoni Tyree
+Cortez Fernandes
+Getsemani Faith
+German Ebert
+Gaston Smithers
+Bennett Gable
+Talya Mahon
+Natan Hendershot
+Frances Kidd
+Lilyan Gough
+Cayleigh Deguzman
+Ismail Messina
+Viggo Thrash
+Lazaro Welker
+Marlow Settle
+Skilar Camden
+River Deleon
+Joziah North
+Benedict Tubbs
+Dallas Robles
+Marlei Marker
+Summit Toland
+Ruthie Cowart
+Ella Cooper
+Kimberlynn Daughtry
+Gray Wylie
+Reilly Marquardt
+Lanae Detwiler
+Jacquelynn Murguia
+Peyton Patel
+Truett Pak
+Royalty Woodall
+Nella Hartnett
+Lincoln Araujo
+Shanice Colunga
+Viviana Clements
+Rania Mcwhorter
+Xoe Binion
+Kirill Garretson
+Giorgio Minnick
+Emmalina Alter
+Kamdyn Platt
+Bristol Estes
+Rochelle Pitre
+Destinee Hummel
+Grecia Tierney
+Dax Ritchie
+Michaela Zhang
+Decker Maier
+Roslyn Mcdonnell
+Adelaida Adrian
+Ved Wegner
+Landon Derose
+Darian Fedor
+Sara Ball
+Cameryn Popovich
+Roan Saxton
+Hartlee Fontanez
+Bailee Dillard
+Leelah Gilmartin
+Zania Willison
+Cristina Whitt
+Trey Wills
+Jalayah Cintron
+Rayden Velasco
+Braylon Huynh
+Kenson Loo
+Kam Hibbs
+Lochlyn Athey
+Mekhi Fish
+Emalee Groff
+Javari Faria
+Awa Halford
+Mattilyn Dills
+Giovani Hannah
+Parker Moody
+Chaim Gallo
+Keiran Standridge
+Blaise Lukens
+Javien Ingersoll
+Rowen Hong
+Kaysen Erdmann
+Khalani Goodall
+Azucena Gregoire
+Anisha Alcaraz
+Kadyn Landau
+Adlee Derr
+Jareth Sandy
+Kendall Cabral
+Maddison Berg
+Tyree Boston
+Saryah Auger
+Meera Bowser
+Angel Jenkins
+Amery Monteleone
+Heidy Mchenry
+Kensley Mcnamara
+Grant Frazier
+Allee Strasser
+Ziggy Gong
+Rosalinda Fleck
+Campbell Foote
+Klaire Pitman
+Baylei Cicero
+Jizelle Bryce
+Miliani Chancellor
+Ashlynne Staub
+Stanley Rainey
+Hatcher Yancy
+Arlen Duhon
+Landon Morgan
+Lariah Bunnell
+Eamonn Pawlak
+Everlee Pappas
+Malak Dawkins
+Eian Pieper
+Ehan Celestine
+Kayson Sanford
+Hillel Sistrunk
+Halina Sowards
+Lance Sheehan
+Paityn Do
+Deklyn Mckeon
+Theophilus Teasley
+Koy Heald
+Eliyana Borrelli
+Minna Barto
+Markell Bianco
+Keylin Deason
+Janylah Kempf
+Ivanka Searle
+Shaylyn Glasser
+Gunner Townsend
+Xavi Brice
+Avaya Begley
+Maizie Cha
+Dinah Strait
+Jenny Rock
+Jhene Almonte
+Zyair Harless
+Palmer Coles
+Kaliana Knighton
+Rudy Bauman
+Gwendalyn Forsberg
+Xochitl Florez
+Jayleigh Guyton
+Ainhoa Arruda
+Nawal Judkins
+Jordi Danielson
+Declyn Bumpus
+Meredith Belcher
+Rueben Putney
+Amira Ellison
+Aayla Sotomayor
+Jett Marks
+Linus Marroquin
+Avary Brittain
+Bronson Bowles
+Maylani Whyte
+Jodie Neale
+Bobbi Lavigne
+Case Bruno
+Adreanna Colyer
+
+Cristiano Spicer
+Fausto Mingo
+Brentlee Worthy
+Neftali Mercurio
+Zayyan Tincher
+Eliyanah Corry
+Amayah Kimble
+Diamond Mccollough
+Fredrick Overstreet
+Devyn Sam
+Alitza Frink
+Nariah Pringle
+Avneet Mannino
+Eamonn Pawlak
+Venus Voigt
+Kamaria Dombrowski
+Akayla Hohman
+Kei Gideon
+Eloisa Lamm
+Jehu Cabello
+Winslow Santini
+Cormac Rooney
+Makaylee Funderburk
+Yolanda Gagne
+Ysabel Longley
+Erin Macdonald
+Eliora Botello
+Aura Kaye
+Hogan Santangelo
+Cameren Weigand
+Sakura Corwin
+Blanca Lindberg
+Dariela Haider
+Zyair Harless
+Ori Pabon
+Henley Wilder
+Dillon Proctor
+Zendaya Babcock
+Reya Penny
+Fareed Krol
+Sury Lock
+Carina Solano
+Tania Houck
+Mykel Ledezma
+Keith Sosa
+Kalista Rath
+Lexani Asuncion
+Juliett Stadler
+Marcia Ahearn
+Jerzey Nemec
+Kendell Demaio
+Kaidyn Hartzell
+Isreal Tribble
+Lillyana Sotelo
+Aadhav Hermanson
+Liya Swope
+Kyran Counts
+Abdulmalik Izquierdo
+Ellinor Garry
+Perrin Tallent
+Dmari Bojorquez
+Parisa Vineyard
+Nayla Blank
+Paradise Meadors
+Eivin Cooksey
+Mirabel Stith
+Taten Hartshorn
+Ellery Friend
+Branden Parnell
+Jusiah Cranston
+Jeter Molloy
+Anaisha Bevan
+Joi Cave
+Makeda Robillard
+Jakhari Simmonds
+Bryton Grasso
+An Milan
+Sequoia Nutt
+Teagen Ivie
+Kacen Ricker
+Emory Downey
+Raleigh Szabo
+Deasia Padron
+Javier Fischer
+Deonta Thrift
+Zailey Lenhart
+Younis Knisley
+Kinlee Barrow
+Zion Eubanks
+Silas Harper
+Jasmin Jorgensen
+Ellia Matheny
+Caiden Underwood
+Paxton Wolf
+Patrick Stanley
+Jayani Lucia
+Leighann Mejias
+Tyus Mchale
+Yitzchok Farias
+Jaziah Buie
+Kenslee Flick
+Miles Kelley
+Gloria Newell
+Quin Rubalcava
+Khali Sines
+Nomar Works
+Priyanka Hansel
+Rheagan Hartfield
+Andrea May
+Aylani Gormley
+Swara Wooldridge
+Nashley Bergin
+Warren Case
+Landin Boettcher
+Jayleen Vaughan
+Advika Nave
+Cristopher Reagan
+Snow Gault
+Abdias Beller
+Kaizer Lawhorn
+Jadyn Hornsby
+Jazleen Wallin
+Allegra Leclair
+Polina Sato
+Maxx Ferrer
+Rima Moncrief
+Ethan Martinez
+Cynthia Law
+Kiarra Autrey
+Carolynn Mincey
+Kendell Thibault
+Dustin Daly
+Ciro Stryker
+Rosemarie Streeter
+Ada Berger
+Arissa Palomino
+Kenlie Halpern
+Kullen Montana
+Majesty Sigler
+Karsynn Harbour
+Nickolai Dossantos
+Awa Halford
+Larson Barta
+Tyrion Somerville
+Esma Eddings
+Camden Fernandez
+Tydus Beggs
+Carmelo Dunham
+Blakely Winters
+Anora Blanks
+Madelyn Shaw
+Kerrigan Coble
+Jaylon Spear
+Jelani Shumaker
+Hadley Jensen
+Marquis Goldsmith
+Aubreyanna Wager
+Amilia Hannon
+Graysen Laird
+Geovanni Mccallum
+Nazareth Gast
+Mylee Sammons
+Wesley Alvey
+Aiyden Santillan
+Jewel Hurd
+Dylan Arias
+Tristan Ferguson
+Madhav Severino
+Marlayna Ericksen
+Kylin Deanda
+Irene Dickinson
+Isha Sebastian
+Marianna Hadley
+Mckenzi Alberts
+Jayana Orcutt
+Elder Fraga
+Arianah Mapp
+Fenton Spano
+Rubi Upton
+Meredith Belcher
+Klay Mallett
+Bellarose Schatz
+Thomas Cox
+Legend Cantu
+Keily Cottrell
+Arleen Millar
+Zakariah Trull
+Aysha Mcauliffe
+Trisha Stull
+Aydrian Belisle
+Lola Mccormick
+Quinn Roach
+Bodie Barney
+Eoin Villalpando
+Suhayla Mask
+Maryama Swaney
+Moussa Ito
+Latham Jakubowski
+Genessis Dominick
+Ambrose Held
+Aaralyn Tiller
+Jalayah Cintron
+Zeppelin Laplante
+Rita Mulligan
+Berklee Sayers
+Jalen Courtney
+Alton Crawley
+Anyiah Tapley
+Mustafa Dumas
+Max Armstrong
+Aranza Carmichael
+Kayley Muse
+Josiah Cruz
+Geovani Kerby
+Lucian Stover
+Koltyn Eisenberg
+Griffen Poon
+Bryanna Godwin
+Violett Godsey
+Lamonte Vaden
+Khadijah Wadsworth
+Elliana Hancock
+Blakley Crowl
+Analie Grable
+Ameenah Surber
+Guy Caron
+Logan Mcintosh
+Xayden Bane
+Waylon Francis
+Aveline Bader
+Darlene Joy
+Brennen Scanlon
+Dominik Quick
+Ellaina Holub
+Dariana Lipscomb
+Camia Revell
+Briggs Coronado
+Avyaan Manns
+Josephine Estrada
+Kelsea Pilcher
+Jena Chaffee
+Uri Melendrez
+Jacee Lent
+Padraig Senior
+Zaiden Hendricks
+Weslyn Helfrich
+Mayer Rohr
+Markell Bianco
+Candace Luciano
+Erabella Mcclean
+Dylon Armbruster
+Agastya Ballew
+Annalyse Wojcik
+Mavis Wilkes
+Tanner Wilkie
+Fatimah Alfonso
+Elyza Mabe
+Jewelz Wille
+Oskar Catalano
+Laniya Sikes
+Esai Lozada
+Jaleigh Sale
+Sebastian Turner
+Elvira Nickell
+Presley Brady
+Bradlee Dykstra
+Jolee Maas
+Teague Delafuente
+Earl Kong
+Alicen Hewlett
+Julieta Wesley
+Legaci Roane
+Alastair Brehm
+Naftuli Seguin
+Soraya Torrez
+Ailany Thomasson
+Angely Sowell
+Adelyne Klotz
+Bay Engstrom
+Darell Sanger
+Simran Spires
+Foster Dow
+Ananya Parrott
+Rishi Wharton
+Camora Huckabee
+Austynn Turgeon
+Melissa Summers
+Mattison Vaccaro
+Evin Lovato
+Violetta Caswell
+Uriah Foreman
+Eniyah Mazzola
+Dannie Cancel
+Ammar Littlejohn
+Callen Finch
+Aveah Nigro
+Cooper Peyton
+Corben Emerick
+Truitt Feinberg
+Royalty Forehand
+Amen Chestnut
+Sherman Woodring
+Reaghan Alam
+Jaida Roper
+Allen Vance
+Lincoln Barnes
+Billie Pickard
+Darwin Calvert
+Halen Boutin
+Ariany Linderman
+Dariyah Nieman
+Nechama Grantham
+Walid Knepper
+Cambrie Finnegan
+Jan Chao
+Karolina Hershberger
+Kohen Hinson
+Micaela Giordano
+Indiana Stidham
+Minnie Shade
+Harper Scott
+Aminata Forster
+Sarina Hwang
+Anastacia Ambriz
+Brylen Lueck
+Booker Humes
+Sandra Arrington
+Janie Brinkley
+Bryer Mclemore
+Blythe Ceja
+Finnick Cartagena
+Maddelyn Gallego
+Zev Barrientos
+Dorian Truong
+Jessi Durden
+Amelia Campbell
+Danae Hermann
+Dmarion Tasker
+Jadelynn Husted
+Aiyanna Priest
+Kit Beaumont
+Bawi Holzer
+Nancy Michel
+Adalyne Goodin
+Kyngston Tingle
+Stirling Cardillo
+Nami Dey
+Zebadiah Birdsall
+Zeina Nussbaum
+Jacori Hiner
+Delilah Davidson
+Tevin Bair
+Vyom Faught
+Jailene Liddell
+Jaleigha Silcox
+River Villanueva
+Braylyn Liggins
+Noe Padgett
+Kaysen Aguilera
+Ozias Pizarro
+Alenna Gonsalez
+Carolyne Rummel
+Reniyah Bengtson
+Marlei Marker
+Charlette Turnage
+Exavier Lebeau
+Blayne Mccallister
+Talan Eck
+Carlisle Bridgeman
+Lamar Wyrick
+Ronav Lofgren
+Thoren Parente
+Marcella Corral
+Theadora Chasteen
+Zerenity Buckler
+Phoebe Dickerson
+Zaya Lanning
+Enoc Rigdon
+Brookelyn Schoonover
+Miya Nowak
+Syncere Dorn
+Jabriel Burciaga
+Rainy Brazell
+Malaysia Krueger
+Layla Sanders
+Marko Hardman
+Findley Waterhouse
+Aryanna Tovar
+Shaurya Parkinson
+Kage Hard
+Yumi Gerken
+Winter Soileau
+Talaya Stutz
+Jacion Monday
+Zoriah Grams
+Huckleberry Biggerstaff
+Asad Yin
+Navy Conlin
+Arya Schulze
+Zury Macdougall
+Collyn Sitton
+Kamori Nevels
+Maylee Vandyke
+Elie Renshaw
+Johnnie Hoy
+Eleen Alfano
+Fradel Frakes
+Eleyna Burgett
+Tory Shropshire
+Romero Holz
+Natalina Starke
+Sianna Mccrory
+Mayeli Geis
+Malea Scofield
+Vishnu Myatt
+Jakeem Tryon
+Hellen Domingo
+Amna Palm
+Shrey Frederickson
+Jacob Garcia
+Shreya Edmondson
+Raylie Mcalpin
+Pilar Sung
+Eshal Maitland
+Haddie Jacques
+Citlali Cousins
+Eason Seay
+Axyl Broadnax
+Brayan Xiong
+Jones Guenther
+Whitlee Kile
+Ena Wortham
+Muhammed Scully
+Capri Saavedra
+Kirra Franke
+Ainsleigh Wan
+Payson Hargrave
+Maisey Lavelle
+Dalylah Dulin
+Ely Donahoe
+Khylen Rowles
+Maryan Bingaman
+Cesar Roth
+Eastyn Almaraz
+Dejon Lenoir
+Clara Jacobs
+Neila Doctor
+Brielle Bates
+Christian Rivera
+Montez Warwick
+Shelton Lehr
+Casimir Eklund
+Becca Moye
+Cassie Michaud
+Khamari Timmerman
+Alaiah Mullinax
+Stacy Beckman
+Valentine Benford
+Lucinda Bertrand
+Saydee Lightfoot
+Shivani Bonnell
+Tierra Pelayo
+Manha Shumate
+Elida Omar
+Kian Merrill
+Cailey Peeples
+Zuleyka Benavidez
+Zaeem Larrabee
+Carmella Epperson
+Carys Soliz
+Kenton Vidal
+Nirvi Starrett
+Mila Henry
+Sherlyn Navarrete
+Finley Mack
+Bridgette Luu
+Jamila Rawlings
+Deklen Lafond
+Bryleigh Raines
+Indra Deegan
+Harriet Baughman
+Deklin Bobbitt
+Kaysen Erdmann
+Trayvon Hutcherson
+Andria Benning
+Brantly Fried
+Tiana Head
+Lucienne Billy
+Beatriz Majors
+Amanuel Bozarth
+Zipporah Hazen
+Brendyn Saito
+Kenzley Solorzano
+Elmer Trammell
+Uzair Giannini
+Nakayla Borland
+Jese Wehner
+Reyes Bosley
+Katiana Mosely
+Shahd Schoenfeld
+Selena Hobbs
+Sadia Cordoba
+Andee Vanegas
+Barbie Sheaffer
+Legacy Chong
+Natalya Duff
+Kamil Silvia
+Musa Shook
+Keyan Brookshire
+Martez Ledoux
+Theia Sledge
+Brekken Tinney
+Stacey Derrick
+Isa Upchurch
+Mariajose Sutter
+Saira Sparrow
+Edan Kowalczyk
+Yahaira Talavera
+Taleen Runge
+Scotland Merry
+Finnian Stockton
+Erick Drake
+Briseyda Bristow
+Lashawn Mccourt
+Infinity Mcgaughey
+Naylah Mulvey
+Kaisyn Dehoyos
+Dana Aragon
+Blake Gould
+Dustyn Manor
+Katherin Burgin
+Josie Colon
+Raymond Pham
+Joziah North
+Samar Hazelwood
+Akemi Brodsky
+Eiden Roney
+Raider Landin
+Scotlynn Backer
+Star Ibrahim
+Effie Bedell
+Dennis Albert
+Shakira Boardman
+Bryan Wade
+Reginae Wulf
+Makenlee Just
+Farida Gourley
+Londyn Baldwin
+Jazel Hummer
+Benyamin Mcabee
+Conlan Roseman
+Jackeline Rupp
+Roy Tillman
+Daila Soles
+Mercedes Comer
+Karla Bright
+Viana Towner
+Stormy Snowden
+Brihanna Wester
+Alexah Lark
+Irving Fahey
+Haziel Frazee
+Kallee Reep
+Jackelyn Carrigan
+Tremaine Mullis
+Rosanna Gaskin
+Valkyrie Voelker
+Arian Wroblewski
+Georgina Wyman
+Adalin Templin
+Channing Paulson
+Lottie Mcvay
+Bruchy Garzon
+Aminah Boucher
+Menachem Arteaga
+Maybree Ginsburg
+Kingston Montgomery
+Emelyn Haller
+Avree Mcglone
+Ruby Bradley
+Amaziah Eastwood
+Donatello Winkle
+Jeremih Kroll
+September Kratzer
+Bode Humphries
+Favian Beecher
+Alexandra Gilbert
+Diana Heath
+Omari Britt
+Bishop Mock
+Adelynn Mathis
+Dinah Strait
+Maddilyn Harry
+Miko Arrieta
+Embry Remington
+Alyzah Maughan
+Devonte Warden
+Jo Fenske
+Carol Freitas
+Jorja Stott
+Darrius Easterling
+Demari Kiefer
+Manar Banister
+Celena Espiritu
+Analiyah Buxton
+Grady Woodard
+Jaydyn Hageman
+Collins Kellum
+Luana Dulaney
+Ishani Dee
+Kareena Salley
+Hazel Dixon
+Brooklynn Blair
+Alonso Greenberg
+Levon Agnew
+Chyanne Gaylord
+Baila Keane
+Layton Christopher
+Prisha Masterson
+Carla Souza
+Annsley Glaze
+Linnea Vanhorn
+Adem Tse
+Bryelle Scalf
+Whitaker Ealy
+Liliann Clemmer
+Slade Scales
+Braxton Silva
+Kynslee Reich
+Ward Garren
+Neko Ayon
+Timber Bradbury
+Crystal Wooten
+Soren Hastings
+Kaela Groh
+Axton Hand
+Everardo Whittle
+Kason Conrad
+Scarlette Heard
+Kenson Loo
+Owen Torres
+Adina Oates
+Caesar Mateo
+Elizah Jeffcoat
+Kaeleigh Routh
+Saja Wilfong
+Samara Sinclair
+Dior Darden
+Jaicee Fuhrman
+Mckinleigh Despain
+Saori Malin
+Korah Keil
+Amorie Moretti
+Leah Hamilton
+Tayson Backus
+Kooper Hairston
+Cruz Grimes
+Louie Nagy
+Jordy Mccord
+Eira Borchardt
+Payslee Breland
+Caelyn Mccutcheon
+Jerry Guthrie
+Reynaldo Forrester
+Kamran Cordes
+Elenore Dyess
+Alainah Spratt
+Kofi Canas
+Corah Kurz
+Sage Bartlett
+Tahir Delp
+Sahar Manriquez
+Wilmer Monroy
+Amare Adair
+Graeme Turpin
+King Guerrero
+Khalani Goodall
+Vihaan Ervin
+Katalyna Guadarrama
+Camdon Probst
+Carrick Hetherington
+Keniyah Davy
+Merrick Mena
+Margaret Mccarthy
+Jaynee Stamp
+Ophelia Sands
+Myiah Valley
+Yelitza Pettus
+Mackson Pitchford
+Zavien Garfield
+Kade Reilly
+Evey Stackhouse
+Ashtyn Damon
+Taya Bateman
+Gema Lerner
+Carrigan Chairez
+Darla Osullivan
+Dionte Bitner
+Beverly Forman
+Elias Rice
+Advay Collard
+Sakina Moller
+Jasean Lowrance
+Anabela Morfin
+Lian Nesbit
+Domenick Poss
+Jahsiah Gwin
+Branton Lerch
+Courtlynn Abbas
+Eidan Beamon
+Jasper Moss
+Leen Brill
+Lakai Chauvin
+Jaxsin Millet
+Zian Recinos
+Marlee Rasmussen
+Haris Shreve
+Daijah Merryman
+Darrick Ressler
+Wolfgang Albertson
+Aliya Smiley
+Deniz Mcdavid
+Janylah Kempf
+Kaylana Arney
+Liliane Kugler
+Zahira Firestone
+Graceson Weidman
+Rain Peter
+Nila Hanlon
+Alston Tedesco
+Aydon Hui
+Benson Esparza
+Jayliah Sluder
+Broxton Foshee
+Leylah Luck
+Treysen Kujawa
+Kezia Fielder
+Kelsie Gage
+Juliette Gibbs
+Charlene Pence
+Yasir Eng
+Brilee Nation
+Edrick Slaton
+Janiah Beaulieu
+Antony Wheat
+Ezekial Danley
+Houston Darnell
+Arianne Mccue
+Jazaria Mccusker
+Viggo Thrash
+Pandora Bode
+Chrisette Wittman
+Phoenix Coffey
+Saige Zapata
+Brileigh Sturdivant
+Karly Graf
+Drea Steelman
+Thatcher Shaver
+Layten Maria
+Fidel Popp
+Janessa Buckner
+Jovanni Banuelos
+Caitlyn Magana
+Ryett Christner
+Aubree Spencer
+Musab Winder
+Atlas Slater
+Alexandros Wayman
+Charlee York
+Lillyan Denham
+Abdallah Batiste
+Dayton Milton
+Woodrow Hung
+Ramon Stern
+Aashi Heintz
+Susie Wheaton
+Livie Glidden
+Tanush Lasalle
+Paola Feldman
+Maddalyn Theisen
+Arjan Freer
+Marwan Gandhi
+Wylder Paddock
+Envy Schock
+Hailee Browne
+Loryn Fiske
+Aizen Sherrod
+Kylei Castanon
+Warner Buchholz
+Kadyn Landau
+Mianna Shock
+Lenny Mccartney
+Mesa Trussell
+Jordany Wingert
+Lizzy Lafountain
+Claude Conners
+Samaya Flannery
+Maddux Kaminski
+Paxon Colter
+Tyleah Mcneese
+Giuliano Messinger
+Yuvaan Traynor
+Joan Rafferty
+Mileena Garay
+Emi Augustine
+Javien Ingersoll
+Gabriel Futrell
+Devante Loving
+Carma Frisbie
+Caliana Strickler
+Amelya Rothstein
+Keyonna Herren
+Braylin Martines
+Jeriah Roundtree
+Clio Campa
+Rudolph Loudermilk
+Kameren Files
+Paloma Barnard
+Deonte Griffis
+Berlynn Quinton
+Alondra Mosley
+Angela Bowers
+Gisselle Knott
+Maejor Pauly
+Franklin Cordova
+Ford Doss
+Luciana Dickson
+Liesel Munro
+Daysha Conard
+Randal Wachter
+Camren Kerns
+Vita Mcelhaney
+Riggins Allgood
+Alder Albin
+Kendal Kitchen
+Fatema Perrotta
+Maliah Connors
+Freddie Caceres
+Uriah Goodnight
+Suri Carlos
+Zena Edens
+Ronnie Zack
+Maritza Coats
+Ashleigh Desantis
+Rylen Squires
+Laikynn Edelstein
+Youssef Ogle
+Harleen Davey
+Hindy Brinker
+Carli Chisholm
+Zada Hague
+Mary Pearson
+Yariel Haskell
+Elisabet Scholten
+Emile Vansickle
+Josias Archuleta
+Miranda Sweeney
+Deanthony Judy
+Kora Rodriquez
+Shayne Bunting
+Elaine Mayes
+Navaeh Watanabe
+Krew Mattox
+Jaiden Tom
+Nasya Loring
+Lacey Werner
+Demya Crumpler
+Randall Toledo
+Dayani Palomo
+Abygail Alba
+Eleanore Winstead
+Kyli Salyers
+Jeylin Million
+Jaleel Bernier
+Yasmin Sheffield
+Cloe Harkness
+Esha Strader
+Aariyah Marley
+Beauregard Trexler
+Safwan Treece
+Khai Henriquez
+Daphney Charleston
+Jesiah Whitmire
+Lexus Button
+Alaric Chatman
+Tamera Senn
+Azrael Sarver
+Ayman Ocasio
+Levi Murphy
+Alyssia Spell
+Erianna Bee
+Gracelyn Mckee
+Zaelynn Shabazz
+Karsen Wold
+Nihira Spiller
+Oona Gooch
+Karl Pfeiffer
+Grant Frazier
+Brandon Owens
+Azalea Whitfield
+Chavy Duffield
+Rowan Eaton
+Evalina Fredericks
+Elanor Rife
+Lian Keener
+Shaylyn Glasser
+Jaivion Carnevale
+Annika Talley
+Waylan Hammel
+Dimitri Prescott
+Salvador Coffman
+Omere Koo
+Millicent Dupre
+Dea Enlow
+Zacharia Neiman
+Caylee Stiles
+Makhi Kumar
+Caden Park
+Maleena Carbaugh
+Alijah Bracken
+Avelyn Vargo
+Rafael Decker
+Nicolo Stroman
+Jayvian Dilley
+Kingdavid Mirza
+Jaelynn Ng
+Osvaldo Goodson
+Damiyah Blodgett
+Avery Neal
+Bennett Day
+Chole Buckman
+Binyomin Ridgway
+Kyndall Trotter
+Shivam Grose
+Aidan Vazquez
+Brie Pounds
+Hillary Shanks
+Zaydin Pattison
+Colbie Chance
+Errol Haugh
+Maahi Ronquillo
+Elisha Gil
+Jacy Burress
+Arlene Epstein
+Tyshaun Hennings
+Johnpaul Brinson
+Kingsley Jarrett
+Madalynn Childress
+Sabir Leininger
+Nour Stephen
+Misha Jacobo
+Ishmael Hopson
+Zyaire Stclair
+Shae Ayres
+Curtis Tracy
+Olan Mong
+Trevon Carreon
+Bridger Nunn
+Sephora Warrick
+Rhythm Fleischer
+Dolores Vanness
+Marielle Westmoreland
+Elnathan Ogletree
+Ameen Nester
+Raylee Bergman
+Lucie Asher
+Matai Esteves
+Keren Agee
+Raylen Linden
+Perry Kelso
+Quinton Gustafson
+Aralynn Guarino
+Bastian Mccrary
+Abdelrahman Rives
+Raniya Otte
+Darnell Longo
+Edvin You
+Kynnedi Drayton
+Cameryn Mariscal
+Everly Vega
+Quinn Munoz
+Leif Stoddard
+Emilia Benson
+Qasim Granado
+Arlo Slay
+Talitha Carper
+Kori Saville
+Guadalupe Chamberlain
+Dawud Ahumada
+Macklin Quinonez
+Akshay Whiteley
+Craig Knutson
+Melannie Vollmer
+Cleo Phelan
+Bowen Helms
+Annmarie Luce
+Kennedy Porter
+Jacari Ferrari
+Lailah Crouch
+Harlem Moreau
+Brailynn Beeman
+Raigan Obregon
+Chavy Duffield
+Dave Amundson
+Khang Heinen
+Meilani Fitch
+Ishan Skipper
+Lahna Bobadilla
+Lotus Sifuentes
+Makenlee Just
+Inna Mentzer
+Darci Grajeda
+Juliano Devera
+Chastity Rentz
+Mathilde Decosta
+Skyler Knox
+Tim Denison
+Aryanna Tovar
+Judah Jasinski
+Cindy Greco
+Kian Merrill
+Hartley Braxton
+Zymere Bainbridge
+Elija Peppers
+Boe Gendron
+Salena List
+Elan Charlton
+Octavio Mayberry
+Korie Curtin
+Madisen Crittenden
+Denver Ashby
+Christan Paugh
+Keisi Duron
+Braylin Martines
+Jaila Homer
+Keelie Spindler
+Leighann Mejias
+Hanan Greenwald
+Esther Saunders
+Nizhoni Grafton
+Jaylyn Mandell
+Mahlon Brooke
+Maayan Calderone
+Marley Soriano
+Emmery Paterson
+Dejah Maddux
+Keely Beall
+Marisela Bontrager
+Mark Mckinney
+Natalina Starke
+Reginae Wulf
+Harlan Wideman
+Buck Caviness
+Nevan Lail
+Rebekah Carver
+Amaryllis Binkley
+Brystal Orton
+Karleigh Staples
+Judah Miranda
+Journee Sexton
+Caelan Truax
+Rowen Gresham
+Renner Kornegay
+Kaili Borja
+Naveen Fast
+Jamar Loomis
+Jerzee Pastrana
+Niah Upshaw
+Oliviana Ranson
+Timofey Dutra
+Zaidyn Lumpkin
+Clifford Ricketts
+Marely Baumgardner
+Carina Solano
+Rusty Squire
+Kamber Almendarez
+Arik Nelsen
+Oakleigh Higgs
+Jaziah Mckeever
+Maylie Grindstaff
+Shane Whitaker
+Makynlee Vicente
+Henson Cowden
+Eve Rowland
+Danah Fragoso
+Katana Farkas
+Dillan Sager
+Canaan Trent
+Corra Kass
+Kwame Penland
+Aishah Ku
+Shamya Saba
+Mykah Ochs
+Gwenyth Matlock
+Kyara Newland
+Naeem Mapes
+Caprice Countryman
+Marshawn Ellington
+Annasophia Bove
+Aubreanna Leboeuf
+Harlym Didonato
+Kaito Skeen
+Adelina Crowley
+Davien Digiacomo
+Mateus Schutt
+Zamarion Busse
+Jazlyn Haney
+Rylan Urban
+Janay Vanburen
+Emberleigh Barroso
+Porter Baran
+Suhaib Zurita
+Adalyne Goodin
+Jayce Burke
+Kamia Svoboda
+Aerial Halter
+Alesha Laboy
+Fabio Reavis
+Clarisa Cogan
+Gibson Mark
+Collier Eberle
+Carrick Hetherington
+Glory Peak
+Arden Bermudez
+Angelynn Geiser
+Audrey Graham
+Karizma Brokaw
+Michele Hulse
+Jahziel Jacquez
+Horacio Dorado
+Izabell Colton
+Remmy Boyette
+Landon Morgan
+Morrigan Philpot
+Skarlet Schuetz
+Miller Kling
+Lacy Trout
+Gregorio Dong
+Kelly Maki
+Reid Hess
+Lian Keener
+Poppy Cagle
+Bea Olney
+Gavyn Dowd
+Sahil Stroup
+Ysabella Trombley
+Joella Reinke
+Ashly Brinkman
+Jalaysia Polite
+Zyler Shen
+Moksh Gulledge
+Chantelle Smedley
+Kaira Conover
+Jessy Fillmore
+Keziah Singletary
+Jaydan Pemberton
+Akai Hedge
+Mirna Braddy
+Skyla Quintero
+Seraphine Bittle
+Damon Haley
+Odalys Salmeron
+Kylea Dowden
+Zaedyn Witcher
+Eoghan Copp
+Zia Devore
+Demarius Endres
+Mariangel Charron
+Anne Holley
+Indiana Langlois
+Azaleah Farah
+Zayvion Mayhew
+Mckinnley Kilby
+Samarah Flack
+Jessy Philpott
+Yulissa Plunkett
+Emy Mak
+Hudsyn Ludlow
+Levi Blaine
+Calina Sisneros
+Callahan Gillen
+Lucille Phelps
+Afton Mcclintock
+Lakelynn Avant
+Sommer Dann
+Linnea Vanhorn
+Lennox Lancaster
+Lilith Oneil
+Luc Son
+Dakota Mccullough
+Dalton Kane
+Zori Ledet
+Georgiana Alicea
+Ansel Main
+Lennon Stinson
+Khaleel Dilorenzo
+Atziri Vereen
+Myra Kern
+Jeancarlo Mcanally
+Jahsir Dressler
+Zayna Rausch
+Kaidyn Hartzell
+Auston Delvecchio
+Karen Kaiser
+Urban Gatto
+Zamiyah Yarborough
+Sherlyn Navarrete
+Casandra Hering
+Carsyn Willey
+Baleigh Mallon
+Blakelee Rodarte
+Meika Cropper
+Lyndi Giffin
+Priya Zaragoza
+Allisyn Ruano
+Graci Ascencio
+Craig Knutson
+Hawa Hofer
+Drew Corey
+Laron Hsieh
+Taran Naughton
+Gracelynne Fiorentino
+Lillianne Mcclinton
+Kingsley Jarrett
+Amanuel Bozarth
+Warren Case
+Semaj Paschal
+Caris Seale
+Wayde Sandhu
+Michal Menke
+Knox Owen
+Kylin Deanda
+Yetzali Moynihan
+Catalia Vong
+Ahad Guth
+Kamea Jiles
+Pepper Cooney
+Ahtziri Nilsen
+Larkin Cottle
+Dakota Olsen
+Trever Kuehl
+Aaden Angel
+Bryston Mustafa
+Rustin Galicia
+Lexani Asuncion
+Mikel Wheatley
+Elizabeth Carter
+Mika Beebe
+Salman Donald
+Kloee Jurgens
+Nariah Pringle
+Donato Gilliard
+Kain Sell
+Lenna Peavy
+Eisley Vann
+Semaj Coley
+Nikole Chiles
+Dariel Dill
+Avery Collins
+Chantal Ruppert
+Eliyah Bethel
+Aspyn Neville
+Giancarlo Queen
+Eden Katz
+Chase Nowlin
+Makenzy Vice
+Alessandra Abbott
+Cady Renz
+Zury Macdougall
+Tyson Christian
+Cloud Gehrke
+Rosie Egan
+Yahir Metcalf
+Zya Fore
+Paloma Barnard
+Arriana Gambrell
+Nika Woodcock
+Sage Stroud
+Dominique Whitlock
+Novalee Wetzel
+Madysen Gilstrap
+Kelly Good
+Adalyn Barnett
+Randi Deboer
+Manolo Apple
+Lainey Blanco
+Verona Burman
+Kacper Hersh
+Elyjah Lemieux
+Paris Jay
+Kobi Torrey
+Robby Gorden
+Skyleigh Coelho
+Maxx Ferrer
+Audriana Eason
+Salah Cornelison
+Otoniel Engels
+Alaya Kurtz
+Yonatan Strunk
+Cataleya Friedman
+Luqman Palomares
+Melony Cassady
+Shourya Magill
+Lundyn Desrosiers
+Jarrell Aubrey
+Windsor Spry
+Madaline Addington
+Niya Reiter
+Jair Sharma
+Amarri Callison
+Daya Harbaugh
+Orianna Monteiro
+Stryder Neary
+Kamora Christman
+Kamdyn Allard
+Mahogany Rupert
+Arsema Chitwood
+Avelina Abrego
+Avani Falcon
+Aydrian Belisle
+Amaiyah Fontes
+Kashton Deluca
+Lillee Slayton
+Sarina Hwang
+Ashur Mckean
+Jaslynn Mancuso
+Alyzah Maughan
+Dawn Hanes
+Naksh Stringfellow
+Makynzie Babin
+Mona Garibay
+Aryam Fortuna
+Mirella Sirois
+Kroy Mayers
+Karson Dorris
+Elisa Terrell
+Alexie Pompa
+Fabrizio Reams
+Janiece Channell
+Karlee Tomlinson
+Talitha Carper
+Zaidan Gruver
+Ruston Sealey
+Ilias Elswick
+Randy Lim
+Daxx Leitch
+Philomena Loper
+Maaz Struck
+Mendy Jacobi
+Sena Kissinger
+Macklin Quinonez
+Layne Peterman
+Dayanara Steel
+Maniyah Warr
+Galilea Crabtree
+Irvin Minter
+Ilona Cureton
+Miriam Villarreal
+Melinda Dowdy
+Yareli Root
+Kabir Devries
+Genesis Stone
+Jazlene Bostwick
+Faigy Soares
+Kennadee Peraza
+Angelique Welsh
+Marciano Rana
+Lynnlee Buell
+Alahna Roos
+Renesmae Suttles
+Iveth Monteith
+Akiva Huntington
+Fox Lo
+Caydon Tollefson
+Aira Telford
+Jaxston Montenegro
+Kaesyn Fessler
+Agustin Malloy
+Naiomi Laroche
+Daelyn Truesdale
+Anna Marshall
+Sullivan Rambo
+Thorin Acuna
+Callie Blake
+Love Moffitt
+Zaeden Ozuna
+Alexiana Threatt
+Saw Earp
+Levy Barner
+Mariano Hein
+Legend Mulkey
+Armon Northcutt
+Saad Deyoung
+Kalia Beavers
+Dusty Thompkins
+Christianna Clanton
+Dempsey Stivers
+Eliza Rojas
+Kasyn Eden
+Ezekial Danley
+Dev Luttrell
+Lux Caddell
+Davontae Scheller
+Azari Soule
+Yovani Jordon
+Mauricio Guy
+Paityn Do
+Hennessey Mccammon
+Ceasar Burlingame
+Paulina Crocker
+Dresden Pitcher
+Tariq Bergstrom
+Annabel Sykes
+Simone Healy
+Camden Fine
+Emelie Sanmiguel
+Emelyn Haller
+Emmaleigh Razo
+Lucio Clarkson
+Kyro Haughton
+Marlie London
+Sachi Creek
+Sirena Hom
+Demarco Covert
+Melanny Mayorga
+Harlowe Walley
+Patrick Stanley
+Kitai Bing
+Zissy Barrington
+Kailey Delaney
+Shekinah Hulett
+Hernan Howes
+Sutton Sorenson
+Ayumi Brockett
+Harini Fulks
+Saylor Snapp
+Hendrix Burson
+Yehoshua To
+Paulo Bare
+Rhian Highsmith
+Jeffrey Carey
+Jordany Wingert
+Arda Bilbrey
+Katiana Mosely
+Wendell Amin
+Alexxa Schuman
+Atarah Maravilla
+Sima Grimsley
+Kasen Ritter
+Jakson Bancroft
+Avigayil Kennon
+Kiersten Tobias
+Klynn Wolters
+Blakeley Whiteman
+Hudson Perry
+Bentlee Houser
+Leasia Urquhart
+Kyngston Tingle
+Dayana Hatcher
+Alivia Osborne
+Savana Thomsen
+Rainier Corpuz
+Leeanna Sikora
+Emili Brainard
+Carlo Curley
+Xavien Cataldo
+Kelani Cunha
+Teagen Shamblin
+Alyssia Spell
+Adrienne Ferris
+Jamiya Pantoja
+Kaydee Vanmeter
+Bakari Krouse
+Jarrod Mccurry
+Grey Creighton
+Truth Petit
+Georgette Kucera
+Maisie Mcgill
+Dallin Bankston
+Melisa Tarr
+Analy Garrity
+Christal Cardin
+Prince Mcfarland
+Kapri Ketcham
+Kaliah Delvalle
+Sahara Crider
+Klarissa So
+Harlen Palmieri
+Atara Gaul
+Kassandra Newsome
+Laiklyn Geraci
+Infinity Mcgaughey
+Kamran Cordes
+Ainhoa Arruda
+Ariadne Biggs
+Camora Huckabee
+Lucian Stover
+Lamiya Alejo
+Morris Mundy
+Carmen Knapp
+Slade Scales
+Roxie Jaquez
+Pyper Helm
+Keyla Purcell
+Fenix Skiles
+Axton Hand
+Nayan Hargraves
+Aadi Sim
+Eva Weaver
+Josalynn Shope
+Vinny Markle
+Rozlyn Hudak
+Jaxyn Palazzo
+Aryana Montano
+Sanaya Mull
+Braxtin Lampert
+Kiarra Autrey
+Aziah Muth
+Jaylynn Whalen
+Raizy Kohn
+Margo Douglass
+Kendal Kitchen
+Martez Ledoux
+Hilary Fender
+Meila Edelman
+Inara Dockery
+Niomi Beachy
+Essie Fanelli
+Noemi Hurtado
+Shmuel Guillory
+Genevie Govea
+Josefina Munguia
+Christian Rivera
+Declyn Bumpus
+Carson Foss
+Gibran Bevins
+Alyssandra Nestor
+Ricardo Cain
+Ember Odonnell
+Ahsan Falconer
+Anushka Harrigan
+Irma Trowbridge
+Dario Thayer
+Legend Cantu
+Thaddeus Hammer
+Bianca Hardin
+Josilyn Aguinaga
+Eli Creasy
+Anvi Ginn
+Caraline Borst
+Danna Dotson
+Melody Lyons
+Evalee Dirks
+Vanya Willman
+Jeison Feliz
+Dariana Lipscomb
+Johnhenry Berge
+Adrina Mancilla
+Zlata Mellinger
+Nicole Bush
+Aminata Forster
+Kayleigh Stephenson
+Clayton Buchanan
+Rylin Czarnecki
+Giovanna Regan
+Zakariya Turley
+Job Lemay
+Kelcie Quimby
+Aariyah Marley
+Braydon Arthur
+Hadlee Coates
+Leslie Ta
+Kingston Montgomery
+Jameson Parada
+Misa Birnbaum
+Scotlyn Totten
+Roslynn Georges
+Elisia Brunelle
+Darrien Larocca
+Neala Presnell
+Cydney Breckenridge
+Mikah Jain
+Brionna Colucci
+Jarell Delano
+Adelle Pinkerton
+Yassin Coward
+Brenda Lilly
+Shemar Mciver
+Hisham Farlow
+Maida Guyer
+Savior Revis
+Liberty Quintana
+Eleen Alfano
+Fiona Logan
+Jezebel Dake
+Nihal Lavallee
+Nivea Brook
+Marla Pride
+Kaylyn Oswald
+Zamir Farrar
+Eli Wood
+Kacy Kreider
+Niall Tyrrell
+Jannat Ammons
+Soledad Seng
+Emina Loney
+Mayleigh Burcham
+Iona Iniguez
+Oden Moorman
+Jay Villa
+Jeimy Caplan
+Adriana Curry
+Maxine Keating
+Brynna Pinson
+Julian Rogers
+Aslan Jeanbaptiste
+Aniston Bustos
+Charlea Peguero
+Atlas Slater
+Jarred Shaner
+Corinne Reece
+Jazaria Mccusker
+Aloni Flower
+Aniylah Koester
+Lamont Marvin
+Stockton Chalmers
+Honor Pauley
+Kourtney Pimentel
+Christabel Schuller
+Zahara Cheney
+Janiyla Culberson
+Shaniyah Weimer
+Maram Willette
+Bowie Dingman
+Emre Mckinzie
+Dalyla Kindred
+Jaydah Nelms
+Riyah Haygood
+Jaythan Martineau
+Mari Harbin
+Carlton Mazur
+Kenslee Flick
+Magali Corbitt
+Paxtyn Bye
+Rubi Upton
+Abdulrahman Valdivia
+Susan Ma
+Yisroel Hearn
+Rudy Bauman
+Ayla Houston
+Saul Lehman
+Aric Rounds
+Sunshine Milne
+Annemarie Mcfarlane
+Belinda Stearns
+Mackson Pitchford
+Analeah Scholl
+Gretchen Hills
+Shilah Peachey
+Trayvon Hutcherson
+Jacory Ober
+Vansh Alegria
+Immanuel Light
+Kamya Volpe
+Jenna Hensley
+Kirby Witkowski
+Jariah Partida
+Shreya Edmondson
+Akash Forest
+Kaelan Medellin
+Sultan Oaks
+Jomar Chartier
+Maher Rashid
+Constantine Peebles
+Caeli Cai
+Camille Montoya
+Unknown Toy
+Danyla Percy
+Marlyn Aucoin
+Maricruz Dail
+Maylen Gartner
+Ronen Stitt
+Silvano Preece
+Easten Prevost
+Lake Hagler
+Cody Gu
+Tierney Banner
+Chancellor Hutchings
+Mehmet Galaviz
+Joab Kapp
+Aylen Bromley
+Aisha Andersen
+Eimy Riojas
+Mackayla Mceachern
+Ione Lamoureux
+Anyiah Tapley
+Kala Mastin
+Demetrius Schmitz
+Zophia Shrum
+Isha Sebastian
+Anay Canty
+Madigan Osterman
+Mollie Yanez
+Keeva Litchfield
+Milly Wimberly
+Akshay Whiteley
+Yahel Barnwell
+Daphney Charleston
+Kenyon Heim
+Cian Myles
+Kynslee Reich
+Wyatt Evans
+Faizan Boice
+Tommie Montalbano
+Kylynn Veal
+Cason Joyce
+Marie Mcdermott
+Saylor Cano
+Roberto Santana
+Annalie Chiang
+Emett Grill
+Valor Morehead
+Aayla Sotomayor
+Ayala Lower
+Harris Seals
+Emari Hovey
+Amin Iglesias
+Cayden Dennis
+Ada Berger
+Braylie Schutte
+Brea Fogle
+Ahna Geist
+Jerzey Nemec
+Amaru Depasquale
+Kinleigh Irving
+Amauri Broome
+Torin Fraley
+Allena Durante
+Abhiram Heffernan
+Champion Honea
+Brayla Krawczyk
+Genavieve Lipp
+Gwendolyn Michael
+Jaylin Yost
+Matilda Justice
+Seraphina Pyle
+Grey Schrader
+Madilynne Tunstall
+Kenzington Ong
+Alisa Keen
+Emilly Moffatt
+Evans Soucy
+Kaylin Jamison
+Echo Pfeifer
+Brysen Weiner
+Deasia Padron
+Iman Laureano
+Jean Jeter
+Larissa Calloway
+Willa Krause
+Adeline Leonard
+Darian Eddy
+Aylin Kerr
+Aidan Vazquez
+Jaxson Ruiz
+Mitchell Ventura
+Cari Beacham
+Sailor Bey
+Payden Bisson
+Lelani Desalvo
+Octavious Lorenzen
+Hardy Jaworski
+Samya Cobbs
+Jaziah Buie
+Josie Colon
+Alexandros Wayman
+Brookelynn Gatlin
+Aahil Oden
+Nivaan Ruble
+Shulem Pagel
+Bronson Bowles
+Haley Horn
+Madison Nelson
+Riggs Trainor
+Yanely Cedillo
+Tyshawn Keeling
+Greyson Pirtle
+Zakiya Guffey
+Alannah Jeffries
+Maci Randall
+Savion Dupont
+Devin Lara
+Elma Tai
+Annalicia Wanner
+Roderick Wakefield
+Meghan Burroughs
+Hogan Santangelo
+Race Marini
+Solomon Calhoun
+Everlee Pappas
+Kaiden Dalrymple
+Luiz Reinert
+Joesph Berardi
+Lenin Schumann
+Mishka Bowes
+Joanna Parrish
+Samiah Jara
+Jordan Powell
+Adalia Colburn
+Haylen Midkiff
+Kenlie Halpern
+Travon Hoag
+Aadyn Bakke
+Jurgen Elia
+Jusiah Cranston
+Elodie Schwarz
+Karalyn Boulware
+Jariel Schiller
+Mackenzy Ippolito
+Kade Reilly
+Kinley Yates
+Omari Britt
+Allyanna Swinford
+Nikolay Ferrier
+Rex Swenson
+Tyrone Huston
+Bryer Mclemore
+Alayah Mayfield
+Zaydee Paulin
+Khalif Spina
+Essa Vannoy
+Ehan Celestine
+Yaniel Shockey
+Mailen Yung
+Jovanna Marmolejo
+Taytum Obrian
+Athalia Serafin
+Valentine Pedigo
+Timur Thrower
+Khole Scribner
+Wisdom Raab
+Deonna Mulholland
+Hayleigh Dias
+Cai Trice
+Katie Booth
+Jeancarlos Camargo
+Hayes Bradberry
+Betsy Bethea
+Jamaria Hardiman
+Arlyn Constantine
+Lenore Roderick
+Zarah Villasenor
+Arionna Slocum
+Yelena Kight
+Marion Anguiano
+Lucero Noll
+Maverick Vaughn
+Karsen Dasilva
+Elissa Randle
+Eesha Arbuckle
+Giovanni George
+Stellan Wofford
+Alayia Hendley
+Avyana Sly
+Kalliope Gingerich
+Aksel Menard
+Braden Fry
+Aalayah Fiedler
+Finn Dougan
+Dirk Delcastillo
+Ashton Austin
+Pranavi Delcid
+Banner Pepin
+Rudolph Loudermilk
+Elektra Schuette
+Naiara Carillo
+Jairo Whittington
+Jalisa Muro
+Benny Parry
+Gabriela Mckenzie
+Rick Chou
+Leopold Strain
+Christen Marcano
+Aavya Rachal
+Monserrath Liao
+Aalyah Collis
+Azael Elrod
+Rima Moncrief
+Favour Mcgann
+Leiana Babbitt
+Kitana Guido
+Matai Esteves
+Jaclyn Babb
+Johanna Marino
+Aleyah Barksdale
+Jori Griner
+Fannie Brister
+Camia Revell
+Jaynee Stamp
+Lars Gilbertson
+Johana Cable
+Haisley Cantwell
+Genesys Poteat
+Wolf Jacks
+Destin Birch
+Brissa Batson
+Darrion Salomon
+Landry Mccollum
+Kaylinn Sharon
+Rooney Middlebrooks
+Anilah Willhite
+Dylann Marchant
+Amoura Mauk
+Gabby Deming
+Kevin Stevens
+Jaden Kingsley
+Zariah Vang
+Jariyah Donato
+Malique Lovelady
+Payden Langan
+Joseangel Makowski
+Elin Mcneal
+Briar Dukes
+Daryl Pease
+Josemaria Embrey
+Iyanna Carrera
+Zaliyah Verduzco
+Lielle Linkous
+Kirill Garretson
+Julien Meier
+Eldon Fell
+Gittel Mcculley
+Calee Gasca
+Devonte Warden
+Shaurya Parkinson
+Rashaun Hammon
+Landen Khan
+Jensen Mayer
+Revan Renaud
+Ayra Lashley
+Galileah Blaney
+Simeon Orellana
+Aela Rayford
+Shaniya Marx
+Neriah Rushing
+Aron Lovell
+Desmond Shannon
+Dempsey Luckett
+Reyli Karns
+Aidan Vos
+Bliss Berglund
+Ayda Dorr
+Landrie Gower
+Leighton Daugherty
+Favor Dupuy
+Maelee Chew
+Hilario Casella
+Japheth Massaro
+Marilynn Quesada
+Acelyn Lavery
+Brynnlee Neuman
+Kelis Munn
+Aidyn Lima
+Lake Marler
+Xaria Almaguer
+Bryant Grady
+Legacy Wooley
+Scarlett Richardson
+Ever Dexter
+Alessandro Payton
+Zaniah Palacio
+Marlo Blessing
+Amiliana Palazzolo
+Vivian Wheeler
+Daylin Bay
+Arya Schulze
+Jazzlyn Pruett
+Dominique Talbert
+Esmee Chinn
+Easton Hammock
+Justice Hanna
+Mylo Belton
+Elloise Arzate
+Martina Grissom
+Skyler Castaneda
+Fermin Peden
+Lucien Bouchard
+Bradleigh Karim
+Edan Kowalczyk
+Kalayah Mick
+Dominik Quick
+Oluwadarasimi Prickett
+Viola Coughlin
+Avrie Bogle
+Veronica Blankenship
+Luka Moser
+Alyson Plummer
+Wynn Dillman
+Kinzleigh Lapierre
+Railey Simonsen
+Cayleigh Deguzman
+Ted Widener
+Judson Benedict
+Lily Reyes
+Vihaan Ervin
+Laura Ibarra
+Arleen Millar
+Brookelyn Schoonover
+Kailah Chrisman
+Shivam Grose
+Shrey Frederickson
+Gianni Godfrey
+Kenadee Armijo
+Francisca Cannady
+Willard Beane
+Jaiyana Hoggard
+Rayna Pierre
+Ramona Paris
+Ellanor Fenwick
+Zenaida Huckaby
+Dev Luttrell
+Ari David
+Jenna Hensley
+Gabe Joe
+Ty Bolton
+Atlas Slater
+Aubreigh Fabian
+Yvette Clancy
+Sparrow Plascencia
+Adabelle Kyser
+Brinkley Pomeroy
+Gracen Haase
+Francesco Chun
+Rayah Steinke
+Kenzleigh Logue
+Abran Canaday
+Egan Vizcarra
+Alexandru Alpert
+Aubrielle Sprague
+Artem Donner
+Carrie Fennell
+Kalissa Murdoch
+Antonia Kiser
+Ariel Becker
+Zayvian Paradise
+Lawson Church
+Elowen Landes
+Rosalinda Fleck
+Belinda Stearns
+Ari Sumner
+Halie Stella
+Keshaun Batt
+Agnes Hinds
+Alexah Lark
+Zakiya Guffey
+Glory Peak
+Markell Bianco
+Gitty Gooden
+Emri Coomer
+Amna Palm
+Jamar Loomis
+Kyla Leach
+Skylar Billings
+Niyla Yaeger
+Scarlette Heard
+Lacy Trout
+Nataliya Lovely
+Leora Bowens
+Shae Ayres
+Mahogany Rupert
+Brynna Pinson
+Oziel Meister
+Reeve Viramontes
+Auriella Minnich
+Divina Bergmann
+Lukah Agosto
+Ameir Honaker
+Braylie Schutte
+Iliana Melvin
+Kwame Penland
+Alayia Hendley
+Hogan Santangelo
+Mckenzee Go
+James Taylor
+Christen Yoshida
+Colston Battaglia
+Azariah Sewell
+Emran Kwak
+Dafne Viera
+Immanuel Light
+Kainan Nero
+Aleigha Brenner
+Mordecai Gosselin
+Teodoro Peer
+Yareni Deel
+Nasya Loring
+Ivey Ashworth
+Anisha Alcaraz
+Anneliese Venegas
+Janylah Kempf
+Brayden Sullivan
+Zaine Kunkel
+Sloan Quiles
+Talia Farrell
+Coy Benner
+Mayleen Toussaint
+Amora Culver
+Vito Dunne
+Raheem Leavitt
+Glen Gerard
+Trisha Stull
+Zacharia Neiman
+Calvin Chambers
+Jencarlos Showalter
+Elloise Arzate
+Anastacia Ambriz
+Alexi Hoyer
+Safwan Treece
+Flavio Natividad
+Deborah Bower
+Freya Mcmahon
+Catelyn Hawkes
+Melanny Mayorga
+Pascual Scheel
+Jamieson Armentrout
+Lillee Slayton
+Hayes Bradberry
+Danyelle Gama
+Dariah Adamski
+Ryley Ahn
+Elida Omar
+Sherry Lear
+Maizey Hector
+Onna Bednar
+Kobe Langley
+Eliyah Bethel
+Sky Hendrick
+Davin Stjohn
+Meir Greenfield
+Eliab Slavin
+Jolina Pelfrey
+Andi Pick
+Allee Strasser
+Carolynn Mincey
+Mackenzi Oceguera
+Leana Knudson
+Demond Harness
+Fallon Henning
+Mirabella Mccleary
+Naya Whaley
+Dennis Albert
+Wynn Kuhns
+Maida Guyer
+Bowie Lombard
+Abbigail Jung
+Whitlee Kile
+Nino Sites
+Abril Dobson
+Briasia Pletcher
+Ellah Mumford
+Elena Dean
+Marlowe Schilling
+Loretta Ojeda
+Torrance Dinardo
+Carissa Ha
+Lia Mercado
+Devante Loving
+Tamya Gurrola
+Kamdyn Platt
+Otis Keys
+Yuvraj Sadowski
+Tanner Goodwin
+Luisa Adamson
+Layah Silvers
+Kameron Abdullah
+Nashley Bergin
+Lea Jewell
+Colter Beverly
+Agastya Ballew
+Jailah Brace
+Campbell Foote
+Louie Nagy
+Erick Drake
+Makiyah Coyne
+Haven Doughty
+Kyle Byrd
+Denim Sarmiento
+Olivier Bear
+Corrina Blais
+Cassia Wampler
+Daven Benn
+Devansh Osteen
+Mischa Lafrance
+Lillian Hughes
+Ilah Bjork
+Jakoby Burrow
+Daizy Koger
+Azaleah Farah
+Nathen Fellows
+Jakyla Labarge
+Artur Harsh
+Graeson Sabin
+Kristyn Troup
+Jeffrey Carey
+Shanaya Callaway
+Jackson Elbert
+Evelyne Belknap
+Malikai Osburn
+Roosevelt Bigham
+Jaiden Tom
+Lakelyn Byler
+Elias Rice
+Dior Darden
+Ainara Purnell
+Amena Ernest
+Alejandra Oconnell
+Kyngston Tingle
+Justyce Broderick
+Abbygail Clevenger
+Estevan Hawes
+Truitt Feinberg
+Lilyanne Guess
+Tenlee Halvorsen
+Milagro Yarnell
+Henleigh Gillispie
+Jeanna Trader
+Thomas Cox
+Najee Mcvicker
+Carlie Cavanaugh
+Jax Alvarenga
+Mckinnley Kilby
+Veer Kimmel
+Chimamanda Napoli
+Cozette Stonge
+Ricki Bessette
+Karsen Dasilva
+Alain Alger
+Jimmy Shirley
+Audric Schmucker
+Calee Gasca
+Anila Lavine
+Ingrid Benavides
+Zahira Firestone
+Dandre Shorter
+Zephaniah Estrella
+Analisa Frankel
+Hernan Howes
+Anna Marshall
+Parks Juan
+Amarion Brink
+Braidyn Kroeger
+Bushra Blackshear
+Izabel Krebs
+Amya Thomason
+Clare Neely
+Harli Dixson
+Aubri Kincaid
+Sabrina Barrera
+Ernesto Carrasco
+Crew Kraft
+Sydnie Rost
+Crimson Carruthers
+Paxtyn Bye
+Florence Sepulveda
+Maddalyn Theisen
+Maya Rose
+Rahma Conlon
+Royce Dale
+Rio Evers
+Cruz Bukowski
+Lawton Campagna
+Kamren Dupree
+Eternity Partin
+Walden Raymer
+Jaretzy Chee
+Yasmin Sheffield
+Hadeel Hoeft
+Donnie Conti
+Omar Mclaughlin
+Alexander Thomas
+Messiah Farina
+Holland Madrid
+Nasir Mcfadden
+Desmond Shannon
+Gwendolyn Michael
+Scout Madsen
+Marshawn Ellington
+Jaythan Martineau
+Amaiah Kunze
+Matilda Justice
+Gabriela Mckenzie
+Shaya Dacosta
+Mariajose Sutter
+Maysen Eckstein
+Naisha Paulk
+Jak Silvey
+Silvana Guerin
+River Villanueva
+Ridley Carnahan
+Divine Hassler
+Rooney Middlebrooks
+Raidyn Lepage
+Perel Guadalupe
+Kayleb Her
+Johannah Merino
+Cedar Kirchner
+Samyah Oleson
+Marbella Siler
+Anabell Bustillos
+Thang Constant
+Kaysen Erdmann
+Dayton Milton
+Braelee Coots
+Caitlyn Magana
+Yadier Ingalls
+Maiah Tobar
+Mitchell Ventura
+Anilah Willhite
+Wyatt Evans
+Devan Waldrop
+Niles Carder
+Alenna Gonsalez
+Taiden Yocum
+Zoi Brawner
+Valentine Pedigo
+Dalton Kane
+Nihira Spiller
+Seven Aitken
+Everett Lawson
+Markeith Mathewson
+Abbey Rhoads
+Aleen Boren
+Abigail Lee
+Delila Fee
+Hanley Jun
+Amari Davila
+Mattison Vaccaro
+Ivette Melson
+Adian Fritsch
+Carson Burns
+Esma Eddings
+Maiya Cornwell
+Lennix Yap
+Doris Derosa
+Anjel Matus
+Namir Lechuga
+Callahan Gillen
+Marietta Ebel
+Naiomi Laroche
+Jethro Huey
+Amberly Lennon
+Khaleel Dilorenzo
+Taha Rohrer
+Avyanna Barrows
+Minka Cascio
+Alston Tedesco
+Delyla Mullaney
+Khaza Hollar
+Eldana Strang
+Kelis Munn
+Jazlyn Haney
+Mahmoud Driggers
+Laycee Stanger
+Maniyah Warr
+Lelani Desalvo
+Chole Buckman
+Krystal Valadez
+Laniah Hake
+Toryn Lozoya
+Monica Corona
+Richelle Standish
+Brook Harwell
+Christine Milligan
+Ryah Mcnamee
+Pax Lamont
+Naeem Mapes
+Embree Chisolm
+Reagan Obrien
+Analeigh Keel
+Fredy Elliot
+Ephraim Hawk
+Aanvi Mader
+Aralyn Klug
+Arien Chafin
+Rene Machado
+Julian Rogers
+Leeah Tolley
+Maesyn Redfern
+Jaxie Mccarroll
+Dakarai Mccandless
+Izzy Earls
+Khalif Spina
+Wilbert Lefler
+Akshay Whiteley
+Janiah Beaulieu
+Aspen Prewitt
+Ciana Schenck
+Lavinia Prior
+Nazareth Gast
+Oumou Powe
+Ryland Matney
+Cheyann Serio
+Shelton Lehr
+Kailynn Pendleton
+Mustafa Dumas
+Tristyn Emanuel
+Kacie Robledo
+Amillia Crabb
+Myer Maine
+Blessyn Mertens
+Elmer Trammell
+Kerry Cumming
+Marisa Kelleher
+Lebron Elledge
+Lyric Chase
+Emersyn House
+Ember Odonnell
+Mckenzi Alberts
+Tymber Stapp
+Adolfo Montanez
+Louella Corso
+Nomar Works
+Analy Garrity
+Arius Dvorak
+Rishabh Rehm
+Sybil Amaral
+Makaela Ducharme
+Khai Felt
+Aariz Dionne
+Anushka Harrigan
+Cayman Lineberry
+Shaelyn Wilhite
+Meena Blumberg
+Alli Dube
+Jamyla Runkle
+Myanna Gaudette
+Kolbi Doster
+Taylar Pegram
+Steele Scroggins
+Adelise Sabol
+Zailey Lenhart
+Zionna Harshman
+Eshan Siebert
+Kirby Witkowski
+Erabella Mcclean
+Malakhi Luong
+Courtland Haworth
+Lila Gallagher
+Jael Whatley
+Campbell Canfield
+Kambree Mazza
+Tevin Bair
+Bodhi Lake
+Tenley Vo
+Kalayah Mick
+Jaiden Morton
+Louisa Quiroz
+Caydon Tollefson
+Adlee Derr
+Maddison Berg
+Caidyn Armas
+Kinzie Furr
+Zania Willison
+Justyce Rugg
+Madilynn Hays
+Reynaldo Forrester
+Cason Joyce
+Saydee Lightfoot
+Rivan Tennison
+Brea Fogle
+Lamiya Alejo
+Alberto Fink
+Bradlee Dykstra
+Emery Coulter
+Gilbert Mcnair
+Ida Bonds
+Crawford Doane
+Sam Connor
+Samaria Amaro
+Elli Ripley
+Martin Burnett
+Kansas Mcadoo
+Darren Holcomb
+Karsten Bussey
+Janet Dubose
+Braven Folk
+Affan Savino
+Zebadiah Birdsall
+Ammy Garduno
+Adore Callan
+Kaliyah Espinosa
+Sammy Brockman
+Finnegan Harding
+Sirena Hom
+Shulem Pagel
+Zoya Donohue
+Yuri Teel
+Andromeda Kuo
+Jahiem Resnick
+Lennox Lancaster
+Rozlyn Hudak
+Unknown Fant
+Alonzo Lugo
+Sabina Loy
+Emre Mckinzie
+Braiden Moseley
+Kaison Thorpe
+Roslyn Mcdonnell
+Arial Mcsweeney
+Alijah Forbes
+Berlyn Aston
+Zaara Lagunas
+Jakhari Simmonds
+Rhema Giddings
+Zalayah Sessoms
+Jazlynn Baez
+Kenedi Holladay
+Kavin Hernandes
+Leonidas Cramer
+Amberlee Carlile
+Mackinley Hamner
+Ocean Whitlow
+Jasai Waring
+Adien Sankey
+Lamar Wyrick
+Blen Dunston
+Madeleine Shields
+Vincenzo Duong
+Braydan Lussier
+Rohen Cusack
+Emmi Castleberry
+Jasmina Lambeth
+Jakub Ritchey
+Taylen Thorp
+Kaidyn Hartzell
+Leasia Urquhart
+Zyra Hadden
+Elynn Galli
+Violet Washington
+Nadia Kemp
+Mathias Downing
+Teagan Conner
+Avalina Polson
+Jrue Killion
+Katlyn Fouts
+Kason Conrad
+Honor Pauley
+Bryant Grady
+Inara Dockery
+Jc Ronan
+Anasophia Dehaan
+Della Coy
+Natalie Myers
+Mavrick Harold
+Brooke Miles
+Rihanna Foy
+Misty Fitts
+Quincey Boots
+Dax Ritchie
+Kianna Moua
+Lazaro Welker
+Nivea Brook
+Ron Ousley
+Austen Malik
+Jameria Lipinski
+Avraham Lauer
+Zadie Whelan
+Ayomide Bash
+Suri Carlos
+Raygen Gamache
+Tydus Beggs
+Maxim Goodrich
+Dempsey Stivers
+Jin Eades
+Olliver Setzer
+Irvin Minter
+Odalys Salmeron
+Blythe Ceja
+Maryanna Turek
+Tyriq Richburg
+Paisley Harrison
+Donte Wing
+Sonja Creamer
+Javen Cone
+Krishna Sword
+Arda Bilbrey
+Collette Aldana
+Mattilyn Dills
+Izabell Colton
+Aubre Roop
+Zuriel Krohn
+Tryston Janson
+Charleston Zook
+Arman Hoyle
+Kaybree Mozingo
+Scarlet Sloan
+Akshaya Breault
+Esdras Parkhurst
+Rochelle Pitre
+Lochlyn Athey
+Jasir Aronson
+Bria Garland
+Charity Stauffer
+Blade Garces
+Mikaila Merriweather
+Kierra Fontaine
+Kayah Jesse
+Siena Abraham
+Theodora Fort
+Samia Zhao
+Brithany Lazar
+Ulises Flood
+Nikayla Ottinger
+Zaden Soria
+Keelan Qualls
+Ahri Gillett
+Marlei Marker
+Myracle Theis
+Abraham Powers
+Lilith Oneil
+Analiese Sonnier
+Ethaniel Gerhart
+Eiley Collum
+Kaylana Arney
+Jannah Moy
+Abubakr Cantor
+Nikhil Lively
+Yulissa Plunkett
+Keelyn Spahr
+Sebastien Smalls
+Jaida Roper
+Tory Shropshire
+Cooper Peyton
+Jayli Rhine
+Anapaula Cann
+Bram Dever
+Dusty Thompkins
+Aubrianna Hathaway
+Elva Roebuck
+Michaella Adamo
+Skylah Morrissey
+Victoria Gomez
+Bryn Scruggs
+Earl Kong
+Nikolai Carney
+Gisele Rains
+Rikki Miley
+Emmet Peoples
+Chad Hagan
+Jaron Regalado
+Amaria Rauch
+Dayron Salguero
+Yael Chavis
+Deliah Laine
+Laniyah Barbour
+Kim Mckeown
+Aleksandra Duenas
+Kenna Roe
+Abram Howe
+Spirit Marrone
+Ralph Muhammad
+Waleed Arreguin
+Armani Beatty
+Karver Swart
+Pablo Mahoney
+Slater Gao
+Hayslee Lampley
+Antonella Corley
+Reid Knopp
+Elize Hamlet
+Kahli Adames
+Katalina Beaver
+Issac Boggs
+Jamison Puga
+Haneen Rome
+Levi Blaine
+Aira Telford
+Bryer Mclemore
+Sanad Pearlman
+Oliviana Ranson
+Jaceion Houk
+Sana Daily
+Archie Easter
+Adamaris Snook
+Keyonna Herren
+Gabriel Futrell
+Keagan Koehler
+Story Mckenney
+Joey Bassett
+Bosco Lieb
+Errol Haugh
+Ripley Bolen
+Koen German
+Damya Kirksey
+Savanah Zheng
+Maddox Foltz
+Jasmine Mccoy
+Balian Lindholm
+Olivia Johnson
+Geronimo Conant
+Marko Hardman
+Ranya Pickle
+Ara Ovalle
+Teagan Power
+Zoha Mcshane
+Devon Paez
+Seerat Desilva
+Keasia Aho
+Ellis Diehl
+Santana Corcoran
+Malea Scofield
+Cree Suzuki
+Ayat Rahn
+Marylou Crippen
+Tim Denison
+Sharon Landis
+Laynie Hitt
+Shiloh Saenz
+Erion Tilson
+Ben Miner
+Caralyn Eichler
+Kiley Bergeron
+Oaklie Fulkerson
+Jaceyon Mallard
+Whitman Cater
+Naveen Fast
+Ebony Hubbell
+Saniah Gilkey
+Analucia Quiroga
+Lyndi Giffin
+Koa Nesbitt
+Dominic Coleman
+Athalia Serafin
+Rolando Ham
+Broderick Lytle
+Adyson Palumbo
+Lincoln Araujo
+Jayana Orcutt
+Alyx Yong
+Shanti Berumen
+Nataley Spielman
+Kaitlin Griffiths
+Caleah Hudspeth
+Belen Sheldon
+Cutter Collado
+Kenzlee Sage
+Canton Ice
+Aili Sartin
+Jamila Rawlings
+Malik Morse
+Makenna Nash
+Maleigha Spruill
+Kinlee Barrow
+Sullivan Rambo
+Jensen Lavender
+Zyaire Stclair
+Janine Chesser
+Bintou Leader
+Candice Searcy
+Andy Gudino
+Valarie Bartel
+Kol Houseman
+Aleah Woodward
+Ailey Duque
+Iain Barden
+Cristopher Reagan
+Samar Hazelwood
+Jaslynn Mancuso
+Skyelar Rhode
+Angelie Steinmetz
+Arlet Letourneau
+Isabell Durbin
+Reuben Keene
+Alton Crawley
+Paola Feldman
+Ziona Baugher
+Diane Basham
+Lisandra Holsinger
+Akil Mash
+Hanah Beckmann
+Laurynn Liss
+Tierra Pelayo
+River Deleon
+Blakelee Rodarte
+Soren Janke
+Livvy Braley
+Karam Bickford
+Alaura Money
+Ivan Bishop
+Inayah Gailey
+Izabelle Bellamy
+Cotton Stiffler
+Damario Hermes
+Torrey Bosse
+Meira Sellars
+Laken Solorio
+Tallulah Noonan
+Tayler Fermin
+Carol Freitas
+Haleigh Brower
+Kalleigh Sandstrom
+Jaycee Mccants
+Charissa Dice
+Kaydin Justus
+Mehki Hotchkiss
+Elexis Roseberry
+Exodus Voight
+Jaxtyn Endicott
+Julieta Wesley
+Van Dickens
+Jeffery Fonseca
+Susannah Earnest
+Catalia Vong
+Maribel Aponte
+Alexie Pompa
+Maximilliano Hagedorn
+Heavenlee Leech
+Marion Ruvalcaba
+Wanda Kenworthy
+Nataleigh Sacco
+Reyaan Kulp
+Murphy Hargis
+Octavian Berk
+Baylee Mcconnell
+Faithlynn Ullrich
+Sedona Strother
+Avielle Herald
+Jerrick Casarez
+Syed Oldham
+Tennessee Hendon
+Keona Kellam
+Aleya Bivins
+Nikole Chiles
+Kanon Clary
+Jancarlos Dana
+Adriano Obryan
+Felipe Engle
+Theodore Mills
+Amorette Cutting
+Raizel Wendel
+Jackelin Petrone
+Zaida Fincher
+Jayce Menchaca
+Jaylinn Hammack
+Brooklyn Mosqueda
+Brittany Booker
+Aiva Fairley
+Asha Kelsey
+Juel Holst
+Janay Vanburen
+Zelia Manes
+Maritza Coats
+Royal Steiner
+Armand Herd
+Nithya Beason
+Elian Saucedo
+Jolene Kay
+Magali Corbitt
+Zak Haile
+Vera Wiggins
+Jaxson Ruiz
+Leliana Drumm
+Jacelyn Bohannon
+Khi Burkes
+Braylen Valentine
+Tylar Pray
+Eniyah Mazzola
+Nestor Skidmore
+Symphony Hudgins
+Kain Sell
+Sapphira Mcmullin
+Alec Zavala
+Krue Victoria
+Dariyah Nieman
+Teegan Griego
+Danthony Hochstetler
+Terron Alleyne
+Boden Kinsey
+Evalynn Hirsch
+Lillie Elder
+Raylin Orosco
+Wednesday Dollar
+Evey Stackhouse
+Maxton Christiansen
+Cristina Whitt
+Kandice Denmark
+Tai Shine
+Leighanna Eady
+Treyson Lebron
+Jules Wooden
+Chana Pagan
+Zavien Garfield
+Izek Pelaez
+Theresa Iverson
+Nakiyah Bolick
+Esmae Buehler
+Gaia Zink
+Albert Faulkner
+Espen Breslin
+Blayke Donofrio
+Alana Wang
+Ona Freitag
+Lucus Dare
+Kalvin Batista
+Azalea Whitfield
+Madisen Crittenden
+Fabian Lam
+Kahlani Berens
+Kaylene Riddick
+Treysen Kujawa
+Rajon Spiker
+Augustus Mcneil
+Meelah Rossetti
+Nickolas Hankins
+Shepard Samson
+Greer Moise
+Alida Danko
+Decker Maier
+Ameen Nester
+Blayden Quevedo
+Isadora Cerda
+Marco Callahan
+Jovi Johnsen
+Nikolay Ferrier
+Nayla Blank
+Nariah Pringle
+Kyndell Kunkle
+Ayman Ocasio
+Akiva Huntington
+Stirling Cardillo
+Emonie Anson
+Cattleya Poindexter
+Karmelo Headrick
+Weldon Sorto
+Amy Joseph
+Nicolette Lenz
+Haydee Trusty
+Starr Rey
+Keandre Click
+Reeves Cueva
+Kasen Ritter
+Kyler Burley
+Gonzalo Askew
+Taylor Mercer
+Elaina Mathews
+Brenner Rosenblum
+Jaydee Pillow
+Luiza Wilmot
+Dea Enlow
+Kennedi Mclean
+Mauricio Guy
+Lainey Blanco
+Joshlynn Bowerman
+Matt Islas
+Lili Marston
+Reggie Kinard
+Diamond Mccollough
+Darrick Ressler
+Yehuda Hare
+Kenslie Spikes
+Amyla Howarth
+Shyla Heredia
+Giulietta Soper
+Aminah Boucher
+Ariya Sterling
+Keiran Standridge
+Kaleia Peckham
+Adisyn Buckles
+Imari Barahona
+Elam Beckwith
+Lailani Ashford
+Graci Ascencio
+Kyrell Pankey
+Valerie Daniel
+Shiv Stillwell
+Finleigh Mears
+Ahsan Falconer
+Kapri Ketcham
+Rafaela Raby
+Cindy Greco
+Ignatius Speck
+Anisa Hiatt
+Hadasa Gustin
+Halen Boutin
+Kynsley Hass
+Dexton Widner
+Kaliana Knighton
+Halina Sowards
+Kristopher Kirkpatrick
+Bruno Painter
+Alexandro Slattery
+Magnus Stapleton
+Santiago Vargas
+Moksh Gulledge
+Asya Hazzard
+Massimo Kopp
+Tea Boldt
+Shriyan Sobel
+Safiya Langer
\ No newline at end of file
diff --git a/Exam/IKT203Exam/DATA/songs.txt b/Exam/IKT203Exam/DATA/songs.txt
new file mode 100644
index 0000000..04a6303
--- /dev/null
+++ b/Exam/IKT203Exam/DATA/songs.txt
@@ -0,0 +1,51 @@
+[records:=50]
+Dire Straits;Love Over Gold;1984;rock;MusicBrainz
+Dire Straits;Expresso Love;1984;rock;MusicBrainz
+Dire Straits;Romeo and Juliet;1984;rock;MusicBrainz
+Dire Straits;Telegraph Road;1984;rock;MusicBrainz
+Dire Straits;Private Investigations;1984;rock;MusicBrainz
+Dire Straits;Tunnel of Love (intro: The Carousel Waltz);1984;rock;MusicBrainz
+Dire Straits;Once Upon a Time in the West;1984;rock;MusicBrainz
+Dire Straits;Going Home (theme from âLocal Heroâ);1984;rock;MusicBrainz
+Ry Cooder;634-5789 (Soulsville, U.S.A.);1980;rock;MusicBrainz
+Rush;The Body Electric;1984;rock;MusicBrainz
+Rush;Afterimage;1984;rock;MusicBrainz
+Rush;Kid Gloves;1984;rock;MusicBrainz
+Rush;Red Lenses;1984;rock;MusicBrainz
+Rush;Red Sector A;1984;rock;MusicBrainz
+Rush;Between the Wheels;1984;rock;MusicBrainz
+Barclay James Harvest;Say Youâll Stay;1984;rock;MusicBrainz
+Dire Straits;Solid Rock;1984;rock;MusicBrainz
+King Crimson;Model Man;1984;rock;MusicBrainz
+King Crimson;No Warning;1984;rock;MusicBrainz
+Queen;Tie Your Mother Down;1977;rock;MusicBrainz
+The Long Ryders;(Sweet) Mental Revenge;1984;rock;MusicBrainz
+Ry Cooder;Crazy âbout an Automobile (Every Woman I Know);1980;rock;MusicBrainz
+Hawkwind;Jack of Shadows;1979;rock;MusicBrainz
+Kauko RöyhkÀ & Narttu;PÀhkinÀpuu;1984;rock;MusicBrainz
+Kauko RöyhkÀ & Narttu;Tuulee;1984;rock;MusicBrainz
+Echo & The Bunnymen;Seven Seas "Life At Brian's - Lean And Hungry";1984;rock;Discogs
+Billy Squier;Signs Of Life;1984;rock;Discogs
+Paul McCartney;No More Lonely Nights;1984;rock;Discogs
+Body Checks;TÀtowiert + Kahlgeschoren;1984;rock;Discogs
+Trust (2);Serre Les Poings;1984;rock;Discogs
+Mama's Boys;Mama's Boys;1984;rock;Discogs
+Def Leppard;High 'N' Dry;1984;rock;Discogs
+Savage Republic;Tragic Figure;1984;rock;Discogs
+The Icicle Works;The Icicle Works;1984;rock;Discogs
+Twisted Sister;We're Not Gonna Take It;1984;rock;Discogs
+The Pogues;The Boys From The County Hell;1984;rock;Discogs
+The Takeaways;Sweet And Sour Volume 2;1984;rock;Discogs
+Rick Springfield;Beautiful Feelings;1984;rock;Discogs
+Vice Squad;Teenage Rampage;1984;rock;Discogs
+The Vipers (4);Outta The Nest;1984;rock;Discogs
+Rolands Gosskör;Genom BarriÀren;1984;rock;Discogs
+Willie Loco Alexander*;Taxi-Stand Diane;1984;rock;Discogs
+Kansas (2);The Best Of Kansas;1984;rock;Discogs
+The Rolling Stones;30 Años De Musica Rock - Salvat;1984;rock;Discogs
+Lindisfarne;Nicely Out Of Tune;1984;rock;Discogs
+Andy Summers;2010 / To Hal And Back;1984;rock;Discogs
+The Beatles;I Feel Fine;1984;rock;Discogs
+Neil Diamond;Love Songs;1984;rock;Discogs
+The Sensational Alex Harvey Band;Live;1984;rock;Discogs
+Subterfuge (10);Who's The Fool;1984;rock;Discogs
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-01/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/Assignment-01/CMakeLists.txt
new file mode 100644
index 0000000..99a3a7e
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-01/CMakeLists.txt
@@ -0,0 +1,40 @@
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+
+
+
+# "ON" = build Option 1, "OFF" = build Option 2.
+option(BUILD_ASSIGNMENT_01_OPTION_1 "Build Assignment Option 1 (Standard)" ON)
+
+add_executable(Assignment-01
+ main.cpp
+)
+
+# Conditionally add the correct source file
+if(BUILD_ASSIGNMENT_01_OPTION_1)
+ # If ON, add option1.cpp and define 'ASSIGNMENT_OPTION=1' for C++
+ target_sources(Assignment-01
+ PRIVATE
+ option1.cpp
+ option1.h
+ )
+ target_compile_definitions(Assignment-01 PRIVATE "ASSIGNMENT_01_OPTION=1")
+else()
+ # If OFF, add option2.cpp and define 'ASSIGNMENT_OPTION=2' for C++
+ target_sources(Assignment-01
+ PRIVATE
+ option2.cpp
+ option2.h
+ )
+ target_compile_definitions(Assignment-01 PRIVATE "ASSIGNMENT_01_OPTION=2")
+endif()
+target_link_libraries(Assignment-01
+ PRIVATE
+ SharedLib
+)
+
+
+add_custom_command(TARGET Assignment-01 POST_BUILD
+ # Add a custom command here if needed
+ COMMAND ${CMAKE_COMMAND} -E echo "Assignment-01 post-build step"
+)
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-01/main.cpp b/Exam/IKT203Exam/Portfolio/Assignment-01/main.cpp
new file mode 100644
index 0000000..02423d9
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-01/main.cpp
@@ -0,0 +1,60 @@
+// Mandatory-02.cpp : Defines the entry point for the application.
+//
+
+/*
+Dear Student,
+
+Remember to follow the coding standards and best practices discussed
+in the portfolio assignment document.
+Good luck with your portfolio!
+
+NB: Do not delete the code below that prints the assignment and option info!
+
+---------------------------------------------------------------------
+*** HOW TO SWITCH BETWEEN OPTION 1 AND OPTION 2 ***
+---------------------------------------------------------------------
+You CANNOT switch options by changing this file.
+
+1. Go to the 'CMakeLists.txt' file for this assignment.
+2. Find the line:
+ option(BUILD_ASSIGNMENT_OPTION_1 "..." ON)
+3. Change 'ON' (for Option 1) to 'OFF' (for Option 2).
+
+*** VERY IMPORTANT: After changing the option ***
+Your project will NOT update until you re-run the CMake configuration.
+
+To force an update (e.g., in Visual Studio):
+- Right-click the 'CMakeLists.txt' file and select 'Configure Cache'.
+- OR, simply delete the 'out' / 'build' folder and rebuild the project.
+---------------------------------------------------------------------
+*/
+
+#include
+#include
+
+static constexpr std::string_view AssignmentName = "Category 1: Lists, Stacks, & Queues";
+
+
+#if ASSIGNMENT_01_OPTION == 1
+#include "option1.h"
+static constexpr std::string_view AssignmentOption = "Option 1 (Standard): Console Text Editor.";
+#elif ASSIGNMENT_01_OPTION == 2
+#include "option2.h"
+static constexpr std::string_view AssignmentOption = "Option 2 (Advanced): Console Music Player.";
+#endif
+
+
+
+int main(int argc, char* argv[])
+{
+ int appStatus = 0;
+ std::cout << AssignmentName << std::endl;
+ std::cout << AssignmentOption << std::endl;
+
+ // Create only core or common code in main.cpp
+ // Use the option header files to implement the specific assignment option logic
+ appStatus = RunApp();
+ return appStatus;
+}
+
+
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-01/option1.cpp b/Exam/IKT203Exam/Portfolio/Assignment-01/option1.cpp
new file mode 100644
index 0000000..4f6efb0
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-01/option1.cpp
@@ -0,0 +1,144 @@
+// Option 1 (Standard): Console Text Editor.
+// Implements the user-facing console loop for the text editor.
+// Handles line editing, undo/redo logic, and print job queue operations.
+
+#include "option1.h"
+#include
+#include "TDoublyLinkedList.h"
+#include "TTreeQueue.h"
+#include "TStack.h"
+#include "Utils.h"
+
+TDoublyLinkedList document;
+TTreeQueue printQueue;
+TStack undoStack, redoStack;
+
+bool running = true;
+int lastIndex = 0;
+std::string deletedLine;
+
+// Undo the last text modification.
+// Reverses INSERT/DELETE actions by applying the inverse operation.
+// Moves reversed action into redoStack.
+void Undo()
+{
+ if (!undoStack.IsEmpty()) {
+ const auto action = undoStack.Pop();
+ if (action.action == INSERT){
+ document.Remove(action.index);
+ }
+ else{
+ document.InsertAtIndex(action.index, action.text);
+ }
+ redoStack.Push(action);
+ }
+}
+
+// Redo the last undone modification.
+// Re-applies an action previously undone.
+// Pushes the executed action back into undoStack.
+void Redo()
+{
+ if (!redoStack.IsEmpty()) {
+ const auto action = redoStack.Pop();
+ if (action.action == INSERT) {
+ document.InsertAtIndex(action.index, action.text);
+ }
+ else {
+ document.Remove(action.index);
+ }
+ undoStack.Push(action);
+ }
+}
+
+// Main menu loop for the Console Text Editor.
+// Provides editing operations, queueing print jobs,
+// and demonstrating FIFO behavior through job processing.
+int RunApp()
+{
+ // Implement the Console Text Editor application logic here
+ while (running) {
+ switch (Utils::Choice()) {
+ case 1: {
+ std::cout << "----------Add line----------" << std::endl;
+ lastIndex = Utils::Insert(document, undoStack, redoStack, lastIndex);
+ break;
+ }
+ case 2: {
+ std::cout << "----------Remove line----------" << std::endl;
+ Utils::PrintList(document);
+ lastIndex = Utils::RemoveLine(document, undoStack, redoStack, lastIndex);
+ break;
+ }
+ case 3: {
+ std::cout << "----------Current document----------" << std::endl;
+ for (int i = 0; i < document.GetSize(); i++) {
+ std::cout << document.GetAtIndex(i) << std::endl;
+ }
+ std::cout << std::endl;
+ break;
+ }
+
+ // Build a single print job containing the entire document.
+ // Snapshot is stored as a single string and enqueued.
+ case 4: {
+ std::cout << "----------Add print job----------" << std::endl;
+
+ if (document.GetSize() == 0) {
+ std::cout << "Document is empty - nothing added to print queue." << std::endl;
+ break;
+ }
+
+ std::string job;
+ for (int i = 0; i < document.GetSize(); i++) {
+ job += document.GetAtIndex(i) + "\n";
+ }
+ printQueue.Enqueue(job);
+ std::cout << "Print job added to queue." << std::endl;
+ break;
+ }
+
+ // Dequeue and print the next print job.
+ // Demonstrates FIFO (First-In-First-Out) queue behavior.
+ case 5: {
+ if (printQueue.IsEmpty()) {
+ std::cout << "No prints jobs in queue." << std::endl;
+ break;
+ }
+
+ std::string job = printQueue.Dequeue();
+ std::cout << "----------Printing job-----------" << std::endl;
+ std::cout << job << std::endl;
+ std::cout << "------------------------------------\n\n";
+ break;
+
+ }
+
+
+ case 6: {
+ std::cout << "----------UNDO----------" <
+#include "option2.h"
+
+static bool SongReadCallback(const int aIndex, const int aTotalCount, const std::string& aArtist, const std::string& aTitle, const std::string& aYear, const std::string& aGenre, const std::string& aSource) {
+ // Implement the logic to process each song read from the file
+ // For example, print the song details to the console
+ std::cout << "Song " << (aIndex + 1) << " of " << aTotalCount << ":\n";
+ std::cout << " Artist: " << aArtist << "\n";
+ std::cout << " Title: " << aTitle << "\n";
+ std::cout << " Year: " << aYear << "\n";
+ std::cout << " Genre: " << aGenre << "\n";
+ std::cout << " Source: " << aSource << "\n\n";
+ // Return true to continue reading more songs
+ return true;
+}
+
+
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-01/option2.h b/Exam/IKT203Exam/Portfolio/Assignment-01/option2.h
new file mode 100644
index 0000000..754f3df
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-01/option2.h
@@ -0,0 +1,10 @@
+// option1.h : Option 2 (Advanced): Console Music Player.
+#pragma once
+
+#ifndef OPTION2_H
+#define OPTION2_H
+
+int RunApp();
+
+
+#endif // OPTION2_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/Assignment-02/CMakeLists.txt
new file mode 100644
index 0000000..a8e906b
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/CMakeLists.txt
@@ -0,0 +1,40 @@
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+
+
+
+# "ON" = build Option 1, "OFF" = build Option 2.
+option(BUILD_ASSIGNMENT_02_OPTION_1 "Build Assignment Option 1 (Standard)" ON)
+
+add_executable(Assignment-02
+ main.cpp
+)
+
+# Conditionally add the correct source file
+if(BUILD_ASSIGNMENT_02_OPTION_1)
+ # If ON, add option1.cpp and define 'ASSIGNMENT_OPTION=1' for C++
+ target_sources(Assignment-02
+ PRIVATE
+ option1.cpp
+ option1.h
+ )
+ target_compile_definitions(Assignment-02 PRIVATE "ASSIGNMENT_02_OPTION=1")
+else()
+ # If OFF, add option2.cpp and define 'ASSIGNMENT_OPTION=2' for C++
+ target_sources(Assignment-02
+ PRIVATE
+ option2.cpp
+ option2.h
+ )
+ target_compile_definitions(Assignment-02 PRIVATE "ASSIGNMENT_02_OPTION=2")
+endif()
+target_link_libraries(Assignment-02
+ PRIVATE
+ SharedLib
+)
+
+
+add_custom_command(TARGET Assignment-02 POST_BUILD
+ # Add a custom command here if needed
+ COMMAND ${CMAKE_COMMAND} -E echo "Assignment-02 post-build step"
+)
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/main.cpp b/Exam/IKT203Exam/Portfolio/Assignment-02/main.cpp
new file mode 100644
index 0000000..f2228b8
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/main.cpp
@@ -0,0 +1,57 @@
+// Mandatory-02.cpp : Defines the entry point for the application.
+//
+
+/*
+Dear Student,
+
+Remember to follow the coding standards and best practices discussed
+in the portfolio assignment document.
+Good luck with your portfolio!
+
+NB: Do not delete the code below that prints the assignment and option info!
+
+---------------------------------------------------------------------
+*** HOW TO SWITCH BETWEEN OPTION 1 AND OPTION 2 ***
+---------------------------------------------------------------------
+You CANNOT switch options by changing this file.
+
+1. Go to the 'CMakeLists.txt' file for this assignment.
+2. Find the line:
+ option(BUILD_ASSIGNMENT_OPTION_1 "..." ON)
+3. Change 'ON' (for Option 1) to 'OFF' (for Option 2).
+
+*** VERY IMPORTANT: After changing the option ***
+Your project will NOT update until you re-run the CMake configuration.
+
+To force an update (e.g., in Visual Studio):
+- Right-click the 'CMakeLists.txt' file and select 'Configure Cache'.
+- OR, simply delete the 'out' / 'build' folder and rebuild the project.
+---------------------------------------------------------------------
+*/
+
+#include
+#include
+
+static constexpr std::string_view AssignmentName = "Category 2: Sorting & Searching";
+
+#if ASSIGNMENT_02_OPTION == 1
+#include "option1.h"
+static constexpr std::string_view AssignmentOption = "Option 1 (Standard): Cruise Ship Manifest.";
+#elif ASSIGNMENT_02_OPTION == 2
+#include "option2.h"
+static constexpr std::string_view AssignmentOption = "Option 2 (Advanced): Combined Corporate Directory.";
+#endif
+
+
+
+int main(int argc, char* argv[])
+{
+ int appStatus = 0;
+ std::cout << AssignmentName << std::endl;
+ std::cout << AssignmentOption << std::endl;
+
+ // Create only core or common code in main.cpp
+ // Use the option header files to implement the specific assignment option logic
+ appStatus = RunApp();
+ return appStatus;
+}
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/option1.cpp b/Exam/IKT203Exam/Portfolio/Assignment-02/option1.cpp
new file mode 100644
index 0000000..5af631d
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/option1.cpp
@@ -0,0 +1,123 @@
+#include
+#include
+#include "option1.h"
+#include
+#include "SharedLib.h"
+#include "TLinkedList.h"
+#include "TPerson.h"
+
+// Entry point for Category 2, Option 1 (Cruise Ship Manifest).
+// Steps:
+// 1) Load names from DATA/random_names.txt into employee and guest lists
+// 2) Merge-sort both lists alphabetically (lastName, firstName)
+// 3) Convert guests to an array and quick-sort by cabinSize, then lastName
+// 4) Allow the user to search (binary search) by surname in the chosen list
+int RunApp()
+{
+ // Path to the names data file.
+ // IMPORTANT: working directory must be set so that "DATA/random_names.txt" resolves correctly.
+ const std::string filename = "DATA/random_names.txt";
+
+ pack("Reading names and grouping them.");
+ // Call the utility function with the name callback
+ readNamesFromFile(filename, onNameRead);
+ pack("Finished reading names.");
+
+ /////////////////////////// Merge sorting ///////////////////////////
+ // Sort both employee and guest linked lists alphabetically
+ // using the linked-list merge sort implementation in TLinkedList.
+ e.Sort();
+ g.Sort();
+ pack("Sorting.");
+ // Attempt at "beautifying" the terminal output somewhat
+ pack("Employees merge sorted alphabetically.");
+ const int employeeSize = e.GetSize();
+ auto** employeeAlphaSort = new TPerson*[employeeSize];
+ printline();
+ for (int i = 0; i < e.GetSize(); i++) {
+ std::cout << "[" << i << "] " << e.GetAtIndex(i).lastName << ", " << e.GetAtIndex(i).firstName
+ << " | status: Employee | cabin size: " << e.GetAtIndex(i).cabinSize << std::endl;
+ employeeAlphaSort[i] = new TPerson(e.GetAtIndex(i));
+ }
+ printline();
+ pack("Guests merge sorted alphabetically.");
+ const int guestSize = g.GetSize();
+ auto** guestAlphaSort = new TPerson*[guestSize];
+ printline();
+ for (int i = 0; i < g.GetSize(); i++) {
+ std::cout << "[" << i << "] " << g.GetAtIndex(i).lastName << ", " << g.GetAtIndex(i).firstName
+ << " | status: Guest | cabin size: " << g.GetAtIndex(i).cabinSize << std::endl;
+ guestAlphaSort[i] = new TPerson(g.GetAtIndex(i));
+ }
+ printline();
+
+ /////////////////////////// Quick sorting ///////////////////////////
+ // Build an array of guests and quick-sort it by:
+ // 1) cabinSize (ascending), then 2) lastName.
+ // This array is used to optimise cabin assignment.
+ // creating array from guest linked list
+ auto** guestList = new TPerson*[guestCount];
+ for (int i = 0; i < guestCount; i++) {
+ guestList[i] = new TPerson(g.GetAtIndex(i));
+ }
+ Utils::QuickSort(guestList, 0, guestCount - 1);
+
+ pack("Guests quick sorted by 1) cabinsize, 2) lastname.");
+ printline();
+ for (int i = 0; i < guestCount; i++) {
+ std::cout << "[" << i << "] " << guestList[i]->lastName << ", " << guestList[i]->firstName
+ << " | cabinSize: " << guestList[i]->cabinSize << std::endl;
+ }
+ printline();
+
+ /////////////////////////// Binary search ///////////////////////////
+ // Let the user choose whether to search employees or guests,
+ // then perform binary search on the corresponding alphabetically
+ // sorted array and print all matches with that surname.
+ int choice;
+ std::string target;
+ std::cout << "What list do you want to search through: \n [1] Employee\n [2] Guest" << std::endl;
+ std::cin >> choice;
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ std::cout << "Enter name to search for: " << std::endl;
+ std::getline(std::cin, target);
+
+switch (choice) {
+ case 1: SearchAndPrint(employeeAlphaSort, employCount, target); break;
+
+ case 2: SearchAndPrint(guestAlphaSort, guestCount, target); break;
+
+ default: {
+ std::cout << "Choice invalid" << std::endl;
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ }
+}
+
+ /////////////////////////// Cleanup before exit ///////////////////////////
+ // Delete all dynamically allocated TPerson objects from:
+ // - alphabetical employee array
+ // - alphabetical guest array
+ // - quick-sorted guestList array
+ // Then clear the linked lists to avoid memory leaks.
+
+ for (int i = 0; i < employeeSize; ++i)
+ delete employeeAlphaSort[i];
+ delete[] employeeAlphaSort;
+
+ for (int i = 0; i < guestSize; ++i)
+ delete guestAlphaSort[i];
+ delete[] guestAlphaSort;
+
+ for (int i = 0; i < guestCount; ++i)
+ delete guestList[i];
+ delete[] guestList;
+
+ while (e.GetSize() > 0)
+ e.Remove(0);
+ while (g.GetSize() > 0)
+ g.Remove(0);
+
+ pack("Cleaned up memory");
+ return 0;
+
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/option1.h b/Exam/IKT203Exam/Portfolio/Assignment-02/option1.h
new file mode 100644
index 0000000..6bebdb4
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/option1.h
@@ -0,0 +1,117 @@
+// Option 1 (Standard): Cruise Ship Manifest.
+// Uses linked lists, merge sort, quick sort, and binary search
+// to manage guest and employee manifests from random_names.txt.
+
+#pragma once
+
+#ifndef OPTION1_H
+#define OPTION1_H
+#include "TLinkedList.h"
+#include "TPerson.h"
+
+// Global lists and counters used across the assignment:
+// - 'e' stores EMPLOYEE records
+// - 'g' stores GUEST records
+// - guestCount / employCount track how many were loaded
+inline TLinkedList g, e;
+inline int guestCount = 0;
+inline int employCount = 0;
+
+
+
+int RunApp();
+
+
+inline void printline()
+{
+ std::cout << "----------------------------------------" << std::endl;
+}
+
+inline void pack(const std::string& line)
+{
+ std::cout << "\n\n\n" << std::endl;
+ printline();
+ std::cout << line << std::endl;
+ printline();
+ std::cout << "\n\n\n" << std::endl;
+}
+
+/**
+ * @brief Callback function to process one name.
+static bool NameReadCallback(const int aIndex, const int aTotalCount, const std::string& aFirstName, const std::string& aLastName)
+{
+ std::cout << "Reading Name " << (aIndex + 1) << " of " << aTotalCount << ": "
+ << aFirstName << " " << aLastName << "\n";
+
+ // We only want to read 10 names (index 0 through 9)
+ // Return false when aIndex is 9 to stop the loop after this one.
+ return (aIndex < 9);
+}
+*/
+
+// Callback used by readNamesFromFile.
+// - Creates a TPerson with status (EMPLOYEE or GUEST)
+// - First 1500 entries are EMPLOYEE, the rest are GUEST
+// - Appends each person to the appropriate linked list and updates counters
+static bool onNameRead(const int aIndex, const int aTotalCount, const std::string& aFirstName, const std::string& aLastName)
+{
+ // Determine status based on index: first 1500 are employees, rest are guests.
+ const ENumStatus status = (aIndex < 1500) ? EMPLOYEE : GUEST;
+
+ const TPerson p(aFirstName, aLastName, status);
+
+
+ if (status == EMPLOYEE) {
+ e.Append(p);
+ employCount++;
+ }
+ else {
+ g.Append(p);
+ guestCount++;
+ }
+
+ std::cout << "[" <= 0 && (targetArray[left]->firstName == target || targetArray[left]->lastName == target)) {
+ --left;
+ }
+
+ // Move right while neighbouring entries share the same first or last name
+ while (right < arraySize && (targetArray[right]->firstName == target || targetArray[right]->lastName == target)) {
+ ++right;
+ }
+
+ for (int i = left + 1; i < right; ++i) {
+ std::cout << "Match found: \nName: " << targetArray[i]->firstName << " "
+ << targetArray[i]->lastName << " | status: " << (targetArray[i]->status == 0 ? "Guest" : "Employee")
+ << " | cabinsize: " << targetArray[i]->cabinSize << "\n" << std::endl;
+ }
+}
+
+
+
+
+
+
+
+#endif // OPTION1_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/option2.cpp b/Exam/IKT203Exam/Portfolio/Assignment-02/option2.cpp
new file mode 100644
index 0000000..3c7fc79
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/option2.cpp
@@ -0,0 +1,8 @@
+// Option 2 (Advanced): Console Music Player.
+
+#include "option2.h"
+
+int RunApp() {
+ // Implement the Console Music Player application logic here
+ return 0;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-02/option2.h b/Exam/IKT203Exam/Portfolio/Assignment-02/option2.h
new file mode 100644
index 0000000..754f3df
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-02/option2.h
@@ -0,0 +1,10 @@
+// option1.h : Option 2 (Advanced): Console Music Player.
+#pragma once
+
+#ifndef OPTION2_H
+#define OPTION2_H
+
+int RunApp();
+
+
+#endif // OPTION2_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/Assignment-03/CMakeLists.txt
new file mode 100644
index 0000000..0bb3ab2
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/CMakeLists.txt
@@ -0,0 +1,44 @@
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+
+
+# "ON" = build Option 1, "OFF" = build Option 2.
+option(BUILD_ASSIGNMENT_03_OPTION_1 "Build Assignment Option 1 (Standard)" ON)
+
+add_executable(Assignment-03
+ main.cpp
+ TBST.cpp
+ TBST.h
+ TEmployee.h
+ TAVL.cpp
+ TAVL.h
+)
+
+# Conditionally add the correct source file
+if(BUILD_ASSIGNMENT_03_OPTION_1)
+ # If ON, add option1.cpp and define 'ASSIGNMENT_OPTION=1' for C++
+ target_sources(Assignment-03
+ PRIVATE
+ option1.cpp
+ option1.h
+ )
+ target_compile_definitions(Assignment-03 PRIVATE "ASSIGNMENT_03_OPTION=1")
+else()
+ # If OFF, add option2.cpp and define 'ASSIGNMENT_OPTION=2' for C++
+ target_sources(Assignment-03
+ PRIVATE
+ option2.cpp
+ option2.h
+ )
+ target_compile_definitions(Assignment-03 PRIVATE "ASSIGNMENT_03_OPTION=2")
+endif()
+target_link_libraries(Assignment-03
+ PRIVATE
+ SharedLib
+)
+
+
+add_custom_command(TARGET Assignment-03 POST_BUILD
+ # Add a custom command here if needed
+ COMMAND ${CMAKE_COMMAND} -E echo "Assignment-03 post-build step"
+)
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.cpp b/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.cpp
new file mode 100644
index 0000000..c6c2ca5
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.cpp
@@ -0,0 +1,243 @@
+#include "TAVL.h"
+#include
+#include
+#include "TTreeQueue.h"
+#include "Utils.h"
+
+// Private helpers
+int TAVL::getHeight(const AVLNode *node)
+{
+ return node ? node->height : 0;
+}
+
+
+int TAVL::getBalance(const AVLNode *node)
+{
+ if (!node)
+ return 0;
+ return getHeight(node->left) - getHeight(node->right);
+}
+
+AVLNode *TAVL::rotateRight(AVLNode *y)
+{
+ if (!y || !y->left)
+ return y;
+
+ AVLNode* x = y->left;
+ AVLNode* n2 = x ? x->right : nullptr;
+
+ x->right = y;
+ y->left = n2;
+
+ x->height = 1 + std::max(getHeight(x->left), getHeight(x->right));
+ y->height = 1 + std::max(getHeight(y->left), getHeight(y->right));
+
+
+ return x;
+}
+
+AVLNode *TAVL::rotateLeft(AVLNode *x)
+{
+ if (!x || !x->right)
+ return x;
+
+ AVLNode* y = x->right;
+ AVLNode* n2 = y ? y->left : nullptr;
+
+ y->left = x;
+ x->right = n2;
+
+ x->height = 1 + std::max(getHeight(x->left), getHeight(x->right));
+ y->height = 1 + std::max(getHeight(y->left), getHeight(y->right));
+
+ return y;
+}
+
+// Recursive AVL insert:
+// - Insert key as in a normal BST.
+// - Update node height.
+// - Compute balance factor and apply the appropriate rotation if unbalanced.
+AVLNode *TAVL::insert(AVLNode *n, const int key)
+{
+ if (!n)
+ return new AVLNode(key);
+ if (key < n->key)
+ n->left = insert(n->left, key);
+ else if (key > n->key)
+ n->right = insert(n->right, key);
+ else
+ return n; // Ignore duplicates
+
+ n->height = 1 + std::max(getHeight(n->left), getHeight(n->right));
+ const int balance = getBalance(n);
+
+ if (balance > 1 && key < n->left->key)
+ {
+ //std::cout << "L-L rotation on [" << n->key << "]" << std::endl; <--- uncomment for terminal output of rotations
+ return rotateRight(n);
+ }
+
+ if (balance < -1 && key > n->right->key)
+ {
+ //std::cout << "R-R rotation on [" << n->key << "]" << std::endl; <--- uncomment for terminal output of rotations
+ return rotateLeft(n);
+ }
+
+ if (balance > 1 && key > n->left->key)
+ {
+ //std::cout << "L-R rotation on [" << n->key << "]" << std::endl; <--- uncomment for terminal output of rotations
+ n->left = rotateLeft(n->left);
+ return rotateRight(n);
+ }
+ if (balance < -1 && key < n->right->key)
+ {
+ //std::cout << "R-L rotation on [" << n->key << "]" << std::endl; <--- uncomment for terminal output of rotations
+ n->right = rotateRight(n->right);
+ return rotateLeft(n);
+ }
+ return n;
+}
+
+void TAVL::preorder(const AVLNode* node)
+{
+ if (!node)
+ return;
+ std::cout << "[" << node->key << "] ";
+ preorder(node->left);
+ preorder(node->right);
+}
+
+void TAVL::inorder(const AVLNode* node)
+{
+ if (!node)
+ return;
+ inorder(node->left);
+ std::cout << "[" << node->key << "] ";
+ inorder(node->right);
+}
+
+void TAVL::postorder(const AVLNode *node)
+{
+ if (!node)
+ return;
+ postorder(node->left);
+ postorder(node->right);
+ std::cout << "[" << node->key << "] ";
+}
+
+void TAVL::levelorder(const AVLNode* node)
+{
+ if (!node)
+ return;
+
+ TTreeQueue q;
+ q.Enqueue(const_cast(node));
+
+ while (!q.IsEmpty()) {
+ const AVLNode* cur = q.Dequeue();
+ std::cout << "[" << cur->key << "] ";
+ if (cur->left)
+ q.Enqueue(cur->left);
+ if (cur->right)
+ q.Enqueue(cur->right);
+ }
+
+}
+
+// Public functions
+/// Insert node Node key value (int)
+/// None
+void TAVL::Insert(const int key)
+{
+ root = insert(root, key);
+}
+
+/// Inorder callback AVLNode *node
+/// Bool
+bool TAVL::Inorder(const AVLNode *node)
+{
+ if (!node)
+ return true;
+ inorder(node);
+ std::cout << std::endl;
+ return true;
+}
+
+/// Postorder callback AVLNode *node
+/// Bool
+bool TAVL::Postorder(const AVLNode *node)
+{
+ if (!node)
+ return true;
+ postorder(node);
+ std::cout << std::endl;
+ return true;
+}
+
+/// Preorder callback AVLNode *node
+/// Bool
+bool TAVL::Preorder(const AVLNode *node)
+{
+ if (!node)
+ return true;
+ preorder(node);
+ std::cout << std::endl;
+ return true;
+}
+
+/// LevelOrder callback AVLNode *node
+/// Bool
+bool TAVL::LevelOrder(const AVLNode *node)
+{
+ if (!node)
+ return true;
+ levelorder(node);
+ std::cout << std::endl;
+ return true;
+}
+
+/// Prints the desired sorting order Callback for the desired ordering algorithm (e.g. PrintOrder(LevelOrder) will print the Level Order algorithm to the terminal)
+/// None
+void TAVL::PrintOrder(FOrderTraversal cb)
+{
+ if (!cb)
+ return;
+ cb(root);
+}
+
+// Helper to build an AVL tree with 'count' unique random keys
+// in the range [minRange, maxRange]. Used only for demonstration in RunApp()
+/// Populates AVL tree The AVL tree to be populated
+///How many elements to be populated into the tree
+///Lower bounds of key value range (e.g., the lower limit of element value)
+///Upper bounds of key value range (e.g., higher limit og element value)
+/// None
+void TAVL::Populate(TAVL* avl, const int count, const int minRange, const int maxRange)
+{
+ std::unordered_set AVLset;
+ for (int i = 0; i < count; i++) {
+ int val = Utils::RandomInt(minRange, maxRange);
+ while (AVLset.count(val))
+ val = Utils::RandomInt(minRange, maxRange);
+ //std::cout << "Inserting [" << val << "]" << std::endl; <----- Uncomment for terminal output of insertions
+ avl->Insert(val);
+ AVLset.insert(val);
+ }
+}
+
+
+
+
+
+
+
+
+
+
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.h b/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.h
new file mode 100644
index 0000000..7f8270c
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TAVL.h
@@ -0,0 +1,51 @@
+#ifndef IKT203_COURSE_ASSIGNMENTS_TAVL_H
+#define IKT203_COURSE_ASSIGNMENTS_TAVL_H
+
+// Node used in the AVL tree.
+// Stores only an integer key and height (no TEmployee data).
+struct AVLNode {
+ int key;
+ AVLNode* left;
+ AVLNode* right;
+ int height;
+
+ explicit AVLNode(const int k) : key(k), left(nullptr), right(nullptr), height(1) {}
+ };
+
+typedef bool (*FOrderTraversal)(const AVLNode* AVLNode);
+
+// Self-balancing AVL tree used to demonstrate rotations and traversals.
+// Only stores integer keys; no payload data is required for this assignment.
+class TAVL {
+private:
+ AVLNode* root;
+
+ static int getHeight(const AVLNode* node);
+ static int getBalance(const AVLNode *node);
+ static AVLNode* rotateRight(AVLNode* y);
+ static AVLNode* rotateLeft(AVLNode* x);
+ static AVLNode* insert(AVLNode* n, int key);
+ static void inorder(const AVLNode* node);
+ static void preorder(const AVLNode* node);
+ static void postorder(const AVLNode* node);
+ static void levelorder(const AVLNode* node);
+
+
+
+public:
+ TAVL() : root(nullptr) {};
+ ~TAVL() = default;
+
+ void Insert(int key);
+ static bool Inorder(const AVLNode* node);
+ static bool Postorder(const AVLNode *node);
+ static bool Preorder(const AVLNode *node);
+ static bool LevelOrder(const AVLNode *node);
+ void PrintOrder(FOrderTraversal);
+ static void Populate(TAVL* AVLtree, int count, int minRange, int maxRange);
+
+
+};
+
+
+#endif //IKT203_COURSE_ASSIGNMENTS_TAVL_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.cpp b/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.cpp
new file mode 100644
index 0000000..c8a16cd
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.cpp
@@ -0,0 +1,202 @@
+#include "TBST.h"
+#include
+#include "TTreeQueue.h"
+
+
+void TBST::destroy(BSTNode *node)
+{
+ if (!node)
+ return;
+ destroy(node->left);
+ destroy(node->right);
+ // TBST owns the TEmployee* stored in each node, so delete it here.
+ delete node->data;
+ delete node;
+}
+
+/// Insert node Node key value (int)
+/// Employee data (TEmployee)
+/// None
+void TBST::Insert(const int key, TEmployee *data)
+{
+ root = insert(root, key, data);
+}
+
+BSTNode* TBST::insert(BSTNode* node, const int key, TEmployee *data)
+{
+ if (node == nullptr) {
+ auto* n = new BSTNode{key, data, nullptr, nullptr};
+ return n;
+ }
+ if (key < node->key)
+ node->left = insert(node->left, key, data);
+ else if (key > node->key)
+ node->right = insert(node->right, key, data);
+ else {
+ // Duplicate key: do not modify the existing node.
+ // 'data' was allocated by the caller, so we must delete it here
+ // to avoid a memory leak.
+ std::cout << "Duplicate key [" << key << "], ignoring insert." << std::endl;
+ delete data;
+ }
+ return node;
+}
+
+/// Search for node Node key value (int)
+/// TEmployee
+TEmployee *TBST::Search(int key) const
+{
+ const BSTNode* result = search(root, key);
+ return result ? result->data : nullptr;
+}
+
+BSTNode* TBST::search(BSTNode* node, const int key)
+{
+ if (node == nullptr)
+ return nullptr;
+ if (key == node->key)
+ return node;
+ if (key < node->key)
+ return search(node->left, key);
+ else
+ return search(node->right, key);
+}
+
+/// Delete node Node key value (int)
+/// None
+void TBST::Delete(const int key)
+{
+ root = remove(root, key);
+}
+
+BSTNode *TBST::remove(BSTNode *node, const int key)
+{
+ if (node == nullptr)
+ return nullptr;
+ if (key < node->key)
+ node->left = remove(node->left, key);
+ else if (key > node->key)
+ node->right = remove(node->right, key);
+ else {
+ // No children
+ if (node->left == nullptr && node->right == nullptr) {
+ delete node->data;
+ delete node;
+ return nullptr;
+ }
+ // Right child only
+ if (node->left == nullptr) {
+ BSTNode* child = node->right;
+ delete node->data;
+ delete node;
+ return child;
+ }
+ // Left child only
+ if (node->right == nullptr) {
+ BSTNode* child = node->left;
+ delete node->data;
+ delete node;
+ return child;
+ }
+ // Two children:
+ // 1) Find the smallest node in the right subtree (inorder successor)
+ // 2) Copy its key + data into the current node
+ // 3) Remove the successor node from the right subtree
+ else {
+ BSTNode* minRight = findMin(node->right);
+ node->key = minRight->key;
+ node->data = minRight->data;
+ node->right = remove(minRight->right, minRight->key);
+ }
+ }
+ return node;
+}
+
+BSTNode* TBST::findMin(BSTNode* node)
+{
+ while (node && node->left)
+ node = node->left;
+ return node;
+}
+
+// Traversals
+// Private helpers
+void TBST::preorder(const BSTNode* node)
+{
+ if (!node)
+ return;
+ std::cout << "[" << node->key << "] ";
+ preorder(node->left);
+ preorder(node->right);
+}
+
+void TBST::inorder(const BSTNode* node)
+{
+ if (!node)
+ return;
+ inorder(node->left);
+ std::cout << "[" << node->key << "] ";
+ inorder(node->right);
+}
+
+void TBST::postorder(const BSTNode *node)
+{
+ if (!node)
+ return;
+ postorder(node->left);
+ postorder(node->right);
+ std::cout << "[" << node->key << "] ";
+}
+
+void TBST::levelorder(const BSTNode* node)
+{
+ if (!node)
+ return;
+
+ TTreeQueue q;
+ q.Enqueue(const_cast(node));
+
+ while (!q.IsEmpty()) {
+ const BSTNode* cur = q.Dequeue();
+ std::cout << "[" << cur->key << "] ";
+ if (cur->left)
+ q.Enqueue(cur->left);
+ if (cur->right)
+ q.Enqueue(cur->right);
+ }
+}
+
+/// Inorder sorting None
+void TBST::Inorder() const
+{
+ inorder(root);
+ std::cout << std::endl;
+}
+
+/// Preorder sorting None
+void TBST::Preorder() const
+{
+ preorder(root);
+ std::cout << std::endl;
+}
+
+/// Postorder sorting None
+void TBST::Postorder() const
+{
+ postorder(root);
+ std::cout << std::endl;
+}
+
+/// LevelOrder sorting None
+void TBST::LevelOrder() const
+{
+ levelorder(root);
+ std::cout << std::endl;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.h b/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.h
new file mode 100644
index 0000000..d9d90ea
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TBST.h
@@ -0,0 +1,44 @@
+#ifndef IKT203_COURSE_ASSIGNMENTS_TBST_H
+#define IKT203_COURSE_ASSIGNMENTS_TBST_H
+#include "TEmployee.h"
+
+// Node in the Binary Search Tree.
+// Owns a single TEmployee* which is deleted by TBST::destroy/remove.
+struct BSTNode {
+ int key; // employee ID
+ TEmployee* data; // employee record
+ BSTNode* left;
+ BSTNode* right;
+};
+
+// Standard Binary Search Tree for TEmployee* keyed by employee ID.
+// Responsibilities:
+// - Owns all TEmployee objects it contains.
+// - Provides insert, search, delete, and four traversal methods.
+class TBST {
+ private:
+ BSTNode* root;
+
+ static BSTNode* insert(BSTNode* node, int key, TEmployee* data);
+ static BSTNode* search(BSTNode* node, int key);
+ static BSTNode* remove(BSTNode* node, int key);
+ static void inorder(const BSTNode* node);
+ static void preorder(const BSTNode* node);
+ static void postorder(const BSTNode* node);
+ static void levelorder(const BSTNode* node);
+ static void destroy(BSTNode* node);
+ static BSTNode* findMin(BSTNode* node);
+
+ public:
+ TBST() = default;
+ ~TBST() {destroy(root);}
+
+ void Insert(int key, TEmployee* data);
+ [[nodiscard]] TEmployee* Search(int key) const;
+ void Delete(int key);
+ void Inorder() const;
+ void Preorder() const;
+ void Postorder() const;
+ void LevelOrder() const;
+};
+#endif //IKT203_COURSE_ASSIGNMENTS_TBST_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TEmployee.h b/Exam/IKT203Exam/Portfolio/Assignment-03/TEmployee.h
new file mode 100644
index 0000000..e9953c3
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TEmployee.h
@@ -0,0 +1,27 @@
+#ifndef IKT203_COURSE_ASSIGNMENTS_TEMPLOYEE_H
+#define IKT203_COURSE_ASSIGNMENTS_TEMPLOYEE_H
+#include
+#include
+
+// Simple employee record used in Category 3.
+// 'id' is set later by IdGenerator and used as the BST key.
+struct TEmployee {
+ std::string firstName;
+ std::string lastName;
+ int id;
+
+ TEmployee(std::string f, std::string l) : firstName(std::move(f)), lastName(std::move(l)) {};
+ ~TEmployee() = default;
+};
+
+
+
+
+
+
+
+
+
+
+
+#endif //IKT203_COURSE_ASSIGNMENTS_TEMPLOYEE_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/TTreeQueue.h b/Exam/IKT203Exam/Portfolio/Assignment-03/TTreeQueue.h
new file mode 100644
index 0000000..847d3f2
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/TTreeQueue.h
@@ -0,0 +1,57 @@
+#ifndef TQUEUE_H
+#define TQUEUE_H
+#define MAX_SIZE 200
+
+#include
+#include "TBST.h"
+
+// Fixed-size circular queue used by the BST and AVL level-order traversals.
+// Stores raw pointers to tree nodes (T*). Does not own the nodes.
+template
+struct TTreeQueue {
+
+ T* queue[MAX_SIZE];
+ int head = 0;
+ int tail = 0;
+ int count = 0;
+
+
+ TTreeQueue() = default;
+ ~TTreeQueue() = default;
+
+ void Enqueue(T* n)
+ {
+ if (n == nullptr)
+ return; // ignore null pointers, nothing to enqueue
+ if (IsFull())
+ throw std::overflow_error("Queue Overflow");
+ queue[tail] = n;
+ tail = (tail + 1) % MAX_SIZE;
+ count++;
+ }
+
+ T* Dequeue()
+ {
+ if (IsEmpty())
+ throw std::underflow_error("Empty Queue");
+ T* n = queue[head];
+ if (n == nullptr)
+ return nullptr;
+ head = (head + 1) % MAX_SIZE;
+ count--;
+ return n;
+ }
+
+ bool IsEmpty() const
+ {
+ return count == 0;
+ }
+
+ bool IsFull() const
+ {
+ return count == MAX_SIZE;
+ }
+};
+
+
+#endif //TQUEUE_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/main.cpp b/Exam/IKT203Exam/Portfolio/Assignment-03/main.cpp
new file mode 100644
index 0000000..078088e
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/main.cpp
@@ -0,0 +1,54 @@
+/*
+Dear Student,
+
+Remember to follow the coding standards and best practices discussed
+in the portfolio assignment document.
+Good luck with your portfolio!
+
+NB: Do not delete the code below that prints the assignment and option info!
+
+---------------------------------------------------------------------
+*** HOW TO SWITCH BETWEEN OPTION 1 AND OPTION 2 ***
+---------------------------------------------------------------------
+You CANNOT switch options by changing this file.
+
+1. Go to the 'CMakeLists.txt' file for this assignment.
+2. Find the line:
+ option(BUILD_ASSIGNMENT_OPTION_1 "..." ON)
+3. Change 'ON' (for Option 1) to 'OFF' (for Option 2).
+
+*** VERY IMPORTANT: After changing the option ***
+Your project will NOT update until you re-run the CMake configuration.
+
+To force an update (e.g., in Visual Studio):
+- Right-click the 'CMakeLists.txt' file and select 'Configure Cache'.
+- OR, simply delete the 'out' / 'build' folder and rebuild the project.
+---------------------------------------------------------------------
+*/
+
+#include
+#include
+
+static constexpr std::string_view AssignmentName = "Category 3: Trees (BST, AVL & RBT)";
+
+#if ASSIGNMENT_03_OPTION == 1
+#include "option1.h"
+static constexpr std::string_view AssignmentOption = "Option 1 (Standard): Employee Directory (BST vs. AVL).";
+#elif ASSIGNMENT_03_OPTION == 2
+#include "option2.h"
+static constexpr std::string_view AssignmentOption = "Option 2 (Advanced): Interpreted Calculator.";
+#endif
+
+
+
+int main(int argc, char* argv[])
+{
+ int appStatus = 0;
+ std::cout << AssignmentName << std::endl;
+ std::cout << AssignmentOption << std::endl;
+
+ // Create only core or common code in main.cpp
+ // Use the option header files to implement the specific assignment option logic
+ appStatus = RunApp();
+ return appStatus;
+}
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/option1.cpp b/Exam/IKT203Exam/Portfolio/Assignment-03/option1.cpp
new file mode 100644
index 0000000..ee045a1
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/option1.cpp
@@ -0,0 +1,97 @@
+#include "option1.h"
+#include
+
+#include "SharedLib.h"
+
+// Entry point for Category 3, Option 1.
+// Demonstrates:
+// 1) Building a BST of 200 employees from DATA/random_names.txt
+// 2) Running all BST traversals
+// 3) Searching and deleting by employee ID
+// 4) Building and printing an AVL tree with random integer keys
+int RunApp() {
+ //Reading names from file for BST population
+ bst = new TBST();
+
+ // Read 200 employees from the names file and populate the BST.
+ // IMPORTANT: Working directory must be the Portfolio/Assignment-03 folder
+ // so that "DATA/random_names.txt" resolves correctly.
+ const std::string filename = "DATA/random_names.txt";
+ readNamesFromFile(filename, onNameRead);
+
+ // --- BST traversals ---
+ // These calls demonstrate all four traversal orders on the employee BST.
+ // Comment out this block if the console output becomes too noisy.
+ pack("Inorder traversal (sorted by ID)");
+ bst->Inorder();
+
+ pack("Level order traversal");
+ bst->LevelOrder();
+
+ pack("Preorder traversal");
+ bst->Preorder();
+
+ pack("Postorder traversal");
+ bst->Postorder();
+
+ // --- BST search demo ---
+ // Ask the user for an ID, search in the BST, and print the matching employee (if any).
+ pack("Search function");
+ std::cout << "\nInput the ID you want to search for\n" << std::endl;
+ int choice;
+ std::cin >> choice;
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ if (const TEmployee* result = bst->Search(choice))
+ std::cout << "Match found:\n" << result->firstName << " " << result->lastName << std::endl;
+ else
+ std::cout << "ID not found" << std::endl;
+
+ // --- BST delete demo ---
+ // Ask the user for an ID, delete it from the BST if it exists,
+ // then print the new inorder traversal to show the updated structure.
+ pack("Remove function");
+ std::cout << "\nInput the ID you want to remove\n" << std::endl;
+ std::cin >> choice;
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ if (const TEmployee* res = bst->Search(choice)) {
+ bst->Delete(choice);
+ std::cout << "ID removed\n" << std::endl;
+ }
+ else
+ std::cout << "ID not found\n" << std::endl;
+ bst->Inorder();
+ // End of BST block
+
+ // --- AVL demo ---
+ // Build an AVL tree using random integers in [1, 200].
+ // This tree only stores keys (no TEmployee data) and is used
+ // to demonstrate balancing and traversals.
+ pack("AVL");
+ avl = new TAVL;
+
+ TAVL::Populate(avl, 100, 1, 200);
+ pack("Inorder");
+ avl->PrintOrder(TAVL::Inorder);
+
+ pack("Postorder");
+ avl->PrintOrder(TAVL::Postorder);
+
+ pack("Preorder");
+ avl->PrintOrder(TAVL::Preorder);
+
+ pack("Levelorder");
+ avl->PrintOrder(TAVL::LevelOrder);
+ // End of AVL block
+
+
+ // --- Cleanup ---
+ // TBST destructor deletes all TEmployee objects it owns.
+ // Here we delete the tree objects themselves to avoid leaks.
+ pack ("Cleaning up");
+ delete bst;
+ delete avl;
+
+ return 0;
+}
+
+
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/option1.h b/Exam/IKT203Exam/Portfolio/Assignment-03/option1.h
new file mode 100644
index 0000000..8318cfc
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/option1.h
@@ -0,0 +1,68 @@
+#pragma once
+
+#ifndef OPTION1_H
+#define OPTION1_H
+
+#include
+#include
+#include "TAVL.h"
+#include "TBST.h"
+#include "TEmployee.h"
+#include "Utils.h"
+
+// Global state for Category 3, Option 1:
+// - bst: owns all TEmployee objects (deleted in TBST destructor)
+// - avl: separate AVL tree used only to demonstrate balancing on int keys
+inline std::unordered_set usedIds;
+static TBST* bst;
+static TAVL* avl;
+
+int RunApp();
+
+// Assign a unique random employee ID in the range [1, 1000].
+// Uses 'usedIds' to avoid duplicates so the BST always has unique keys.
+inline void IdGenerator(TEmployee* employee)
+{
+ int id = Utils::RandomInt(1, 1000);
+
+ while (usedIds.count(id) > 0)
+ id = Utils::RandomInt(1, 1000);
+
+ usedIds.insert(id);
+ employee->id = id;
+}
+
+// Callback used by readNamesFromFile.
+// - Creates a new TEmployee from the given name.
+// - Stops after 200 employees (as required by the assignment).
+// - Generates a unique ID and inserts the employee into the BST.
+static bool onNameRead(const int index, const int aTotalCount, const std::string& aFirstName, const std::string& aLastName)
+{
+ const auto e = new TEmployee(aFirstName, aLastName);
+ if (index >= 200)
+ return false;
+ IdGenerator(e);
+ bst->Insert(e->id, e);
+
+ std::cout << "[" << e->id << "] " << e->firstName << ", " << e->lastName << std::endl;
+
+ return true;
+}
+
+inline void printline()
+{
+ std::cout << "----------------------------------------" << std::endl;
+}
+
+// Helper to visually separate different demos (traversals, search, etc.) in the console output.
+inline void pack(const std::string& line)
+{
+ std::cout << "\n\n\n" << std::endl;
+ printline();
+ std::cout << line << std::endl;
+ printline();
+}
+
+
+
+#endif // OPTION1_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/option2.cpp b/Exam/IKT203Exam/Portfolio/Assignment-03/option2.cpp
new file mode 100644
index 0000000..ead6154
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/option2.cpp
@@ -0,0 +1,6 @@
+#include "option2.h"
+
+int RunApp() {
+ // Implement the Console Music Player application logic here
+ return 0;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-03/option2.h b/Exam/IKT203Exam/Portfolio/Assignment-03/option2.h
new file mode 100644
index 0000000..7813abf
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-03/option2.h
@@ -0,0 +1,9 @@
+#pragma once
+
+#ifndef OPTION2_H
+#define OPTION2_H
+
+int RunApp();
+
+
+#endif // OPTION2_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/Assignment-04/CMakeLists.txt
new file mode 100644
index 0000000..87888c4
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/CMakeLists.txt
@@ -0,0 +1,38 @@
+set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD_REQUIRED ON)
+
+
+# "ON" = build Option 1, "OFF" = build Option 2.
+option(BUILD_ASSIGNMENT_04_OPTION_1 "Build Assignment Option 1 (Standard)" ON)
+
+add_executable(Assignment-04
+ main.cpp
+ option1.cpp
+)
+
+if(BUILD_ASSIGNMENT_04_OPTION_1)
+ target_sources(Assignment-04
+ PRIVATE
+ option1.cpp
+ option1.h
+ )
+ target_compile_definitions(Assignment-04 PRIVATE "ASSIGNMENT_04_OPTION=1")
+else()
+ target_sources(Assignment-04
+ PRIVATE
+ option2.cpp
+ option2.h
+ )
+ target_compile_definitions(Assignment-04 PRIVATE "ASSIGNMENT_04_OPTION=2")
+endif()
+
+target_link_libraries(Assignment-04
+ PRIVATE
+ SharedLib
+)
+
+
+add_custom_command(TARGET Assignment-04 POST_BUILD
+ # Add a custom command here if needed
+ COMMAND ${CMAKE_COMMAND} -E echo "Assignment-04 post-build step"
+)
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/main.cpp b/Exam/IKT203Exam/Portfolio/Assignment-04/main.cpp
new file mode 100644
index 0000000..898323f
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/main.cpp
@@ -0,0 +1,55 @@
+/*
+Dear Student,
+
+Remember to follow the coding standards and best practices discussed
+in the portfolio assignment document.
+Good luck with your portfolio!
+
+NB: Do not delete the code below that prints the assignment and option info!
+
+---------------------------------------------------------------------
+*** HOW TO SWITCH BETWEEN OPTION 1 AND OPTION 2 ***
+---------------------------------------------------------------------
+You CANNOT switch options by changing this file.
+
+1. Go to the 'CMakeLists.txt' file for this assignment.
+2. Find the line:
+ option(BUILD_ASSIGNMENT_OPTION_1 "..." ON)
+3. Change 'ON' (for Option 1) to 'OFF' (for Option 2).
+
+*** VERY IMPORTANT: After changing the option ***
+Your project will NOT update until you re-run the CMake configuration.
+
+To force an update (e.g., in Visual Studio):
+- Right-click the 'CMakeLists.txt' file and select 'Configure Cache'.
+- OR, simply delete the 'out' / 'build' folder and rebuild the project.
+---------------------------------------------------------------------
+*/
+
+#include
+#include
+#include "option1.h"
+static constexpr std::string_view AssignmentName = "Category 4: Graphs & Dijkstra's Algorithm";
+static constexpr std::string_view AssignmentOption = "Option 1 (Standard): Data Center Network Monitor.";
+
+/*
+#if ASSIGNMENT_04_OPTION == 1
+#include "option1.h"
+#elif ASSIGNMENT_04_OPTION == 2
+static constexpr std::string_view AssignmentOption = "Option 2 (Advanced): Inter-city Logistics Router.";
+#include "option2.h"
+#endif
+*/
+
+int main(int argc, char* argv[])
+{
+ int appStatus = 0;
+ std::cout << AssignmentName << std::endl;
+ std::cout << AssignmentOption << std::endl;
+
+
+ // Create only core or common code in main.cpp
+ // Use the option header files to implement the specific assignment option logic
+ appStatus = RunApp();
+ return appStatus;
+}
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/option1.cpp b/Exam/IKT203Exam/Portfolio/Assignment-04/option1.cpp
new file mode 100644
index 0000000..f44cc91
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/option1.cpp
@@ -0,0 +1,274 @@
+#include "option1.h"
+#include
+#include "SharedLib.h"
+#include
+
+constexpr float INF = 1e9f;
+
+// Global graph storage and lookup table used by the ReadGraph callbacks.
+// These are populated automatically when readGraphFromFile(...) is executed.
+Graph g;
+std::unordered_map nameToIndex;
+std::string filename = "DATA/network_graph.txt"; // Remember to set working directory for this path to work
+
+//////////////////////////////// Callbacks ////////////////////////////////
+// Callback: called once for each node read from network_graph.txt.
+// Responsible for registering the vertex in the graph and recording its index.
+
+bool onNodeRead(const int aIndex, const int aTotalCount, const std::string& aNode)
+{
+ const int idx = g.AddVertex(aNode);
+ nameToIndex[aNode] = idx;
+ return true;
+}
+
+// Callback: called for each edge (connection) read from the file.
+// Translates node names into vertex indices and adds an undirected weighted edge.
+bool onEdgeRead(const int aIndex, const int aTotalCount, const std::string& aFromNode, const std::string& aToNode, const float aWeight)
+{
+ const int fromIdx = nameToIndex[aFromNode];
+ const int toIdx = nameToIndex[aToNode];
+
+ g.AddUndirectedEdge(fromIdx, toIdx, aWeight);
+ return true;
+}
+
+//////////////////////////////// Dijkstra algorithm ////////////////////////////////
+// Computes the shortest path between src and dst using Dijkstra's algorithm.
+// Uses the custom MinHeap class as the priority queue.
+// Output: 'outPath' contains vertex indices from src -> dst in order.
+// Returns INF if no path exists.
+float Dijkstra(const Graph& graph, int src, int dst, std::vector& outPath)
+{
+ const int n = graph.GetVertexCount();
+
+ std::vector dist(n, INF);
+ std::vector prev(n, -1);
+ std::vector visited(n, false);
+
+ dist[src] = 0.0f;
+
+ MinHeap heap;
+ heap.Push(src, 0.0f);
+
+ // Pop the next closest unvisited vertex. Old entries with outdated distances
+ // are skipped via the 'visited' array (lazy deletion).
+ while (!heap.isEmpty()) {
+ HeapNode* node = heap.Pop();
+ const int u = node->vertex;
+ // float d = node->distance; not needed
+ delete node;
+
+ if (visited[u])
+ continue;
+ visited[u] = true;
+ if (u == dst)
+ break;
+
+ for (const TEdge* e : graph.GetEdges(u)) {
+ int v = e->toIndex;
+ float w = e->weight;
+
+ if (visited[v])
+ continue;
+ if (dist[u] + w < dist[v]) {
+ dist[v] = dist[u] + w;
+ prev[v] = u;
+ heap.Push(v, dist[v]);
+ }
+ }
+ }
+
+ outPath.clear();
+ if (dist[dst] == INF)
+ return INF;
+ for (int v = dst; v != -1; v = prev[v])
+ outPath.push_back(v);
+ std::reverse(outPath.begin(), outPath.end());
+ return dist[dst];
+}
+
+//////////////////////////////// Class logic ////////////////////////////////
+// Graph
+// Clean up all dynamically allocated vertices and edges.
+// Graph owns all TVertex* and TEdge*.
+Graph::~Graph()
+{
+ for (TVertex* v : vertices) {
+ for (TEdge* e : v->edges) {
+ delete e;
+ }
+ delete v;
+ }
+}
+
+int Graph::AddVertex(const std::string& name)
+{
+ auto* v = new TVertex;
+ v->name = name;
+ vertices.push_back(v);
+ return static_cast(vertices.size()) - 1;
+}
+
+void Graph::AddUndirectedEdge(int fromIndex, int toIndex, float weight)
+{
+ TEdge* e1 = new TEdge;
+ e1->toIndex = toIndex;
+ e1->weight = weight;
+
+ TEdge* e2 = new TEdge;
+ e2->toIndex = fromIndex;
+ e2->weight = weight;
+
+ vertices[fromIndex]->edges.push_back(e1);
+ vertices[toIndex]->edges.push_back(e2);
+}
+
+int Graph::GetVertexCount() const
+{
+ return static_cast(vertices.size());
+}
+
+const TVertex *Graph::GetVertex(int index) const
+{
+ return vertices[index];
+}
+
+const std::vector& Graph::GetEdges(const int index) const
+{
+ return vertices[index]->edges;
+}
+
+// Heap
+// Min-heap storing (vertex, distance) pairs.
+// Used by Dijkstra as a priority queue.
+MinHeap::~MinHeap()
+{
+ for (HeapNode* n : data)
+ delete n;
+}
+
+bool MinHeap::isEmpty() const
+{
+ return data.empty();
+}
+
+void MinHeap::Push(int vertex, float dist)
+{
+ auto* n = new HeapNode{vertex, dist};
+ data.push_back(n);
+ HeapUp(static_cast(data.size()) - 1);
+}
+
+HeapNode* MinHeap::Pop()
+{
+ if (data.empty())
+ return nullptr;
+
+ HeapNode* root = data[0];
+ data[0] = data.back();
+ data.pop_back();
+ if (!data.empty())
+ HeapDown(0);
+ return root;
+}
+
+void MinHeap::HeapUp(int idx)
+{
+ while (idx > 0) {
+ int parent = (idx - 1) / 2;
+ if (data[parent]->distance <= data[idx]->distance)
+ break;
+ std::swap(data[idx], data[parent]);
+ idx = parent;
+ }
+}
+
+void MinHeap::HeapDown(int idx)
+{
+ int n = static_cast(data.size());
+
+ while (true) {
+ int left = 2 * idx + 1;
+ int right = 2 * idx + 2;
+ int smallest = idx;
+
+ if (left < n && data[left]->distance < data[smallest]->distance)
+ smallest = left;
+ if (right < n && data[right]->distance < data[smallest]->distance)
+ smallest = right;
+
+ if (smallest == idx)
+ break;
+ std::swap(data[idx], data[smallest]);
+ idx = smallest;
+ }
+}
+
+
+// Entry point for Assignment 04 Option 1.
+// Loads the network graph from file, prints node list,
+// prompts the user for source and destination,
+// and runs Dijkstra to find the lowest-latency path.
+int RunApp() {
+
+ readGraphFromFile(filename, onNodeRead, onEdgeRead);
+
+ // Debug: Print all nodes and vertices
+ /*
+ pack("Graph");
+ for (int i = 0; i < g.GetVertexCount(); i++) {
+ const TVertex* v = g.GetVertex(i);
+ std::cout << i << ": " << v->name << std::endl;
+ for (const TEdge* e : g.GetEdges(i)) {
+ std::cout << " -> " << e->toIndex << " (weight = " << e->weight << ")" << std::endl;
+ }
+ }
+ */
+ /* Debug heap test
+ pack("Heap");
+ MinHeap test;
+ test.Push(1, 5.0f);
+ test.Push(2, 3.0f);
+ test.Push(3, 10.0f);
+ while (!test.isEmpty())
+ {
+ const HeapNode* n = test.Pop();
+ std::cout << "(" << n->vertex << ", " << n->distance << ")" << "\n";
+ delete n;
+ }
+ printline();
+ */
+
+ std::cout << "\nGraph:" << std::endl;
+ for (int i = 0; i < g.GetVertexCount(); ++i)
+ std::cout << i << ": " << g.GetVertex(i)->name << std::endl;
+
+ int src, dst;
+ std::cout << "\nEnter source index: ";
+ std::cin >> src;
+ std::cout << "\nEnter destination index: ";
+ std::cin >> dst;
+ if (src < 0 || src >= g.GetVertexCount() ||
+ dst < 0 || dst >= g.GetVertexCount()) {
+ std::cout << "Invalid indices.\n";
+ return 0;
+ }
+
+ std::vector path;
+ float total = Dijkstra(g, src, dst, path);
+
+ if (total >= INF) {
+ std::cout << "\nNo path between those nodes.\n";
+ } else {
+ std::cout << "\nLowest latency path: ";
+ for (size_t i = 0; i < path.size(); ++i) {
+ std::cout << g.GetVertex(path[i])->name;
+ if (i + 1 < path.size()) std::cout << " -> ";
+ }
+ std::cout << " \n(Total: " << total << " ms)\n";
+ }
+ printline();
+
+ return 0;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/option1.h b/Exam/IKT203Exam/Portfolio/Assignment-04/option1.h
new file mode 100644
index 0000000..258eac5
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/option1.h
@@ -0,0 +1,84 @@
+#pragma once
+
+#ifndef OPTION1_H
+#define OPTION1_H
+#include
+#include
+#include
+#include
+
+// Structs and classes
+struct TEdge {
+ int toIndex;
+ float weight;
+};
+
+struct TVertex {
+ std::string name;
+ std::vector edges;
+};
+
+struct HeapNode {
+ int vertex;
+ float distance;
+};
+
+class MinHeap {
+private:
+ std::vector data;
+
+ void HeapUp(int idx);
+ void HeapDown(int idx);
+
+public:
+ ~MinHeap();
+
+ [[nodiscard]] bool isEmpty() const;
+ void Push(int vertex, float dist);
+ HeapNode* Pop();
+
+};
+
+class Graph {
+private:
+ std::vector vertices; // Owns all TVertex*
+
+public:
+ ~Graph();
+
+ int AddVertex(const std::string& name);
+ void AddUndirectedEdge(int fromIndex, int toIndex, float weight);
+
+ [[nodiscard]] int GetVertexCount() const;
+ [[nodiscard]] const TVertex* GetVertex(int index) const;
+ [[nodiscard]] const std::vector& GetEdges(int index) const;
+};
+
+// Callbacks & funcs
+bool onNodeRead(int aIndex, int aTotalCount, const std::string& aNode);
+bool onEdgeRead(int aIndex, int aTotalCount, const std::string& aFromNode, const std::string& aToNode, float aWeight);
+
+float Dijkstra(const Graph& graph, int src, int dst, std::vector& outPath);
+
+// Terminal tidying
+inline void printline()
+{
+ std::cout << "----------------------------------------" << std::endl;
+}
+
+inline void pack(const std::string& line)
+{
+ std::cout << "\n\n\n" << std::endl;
+ printline();
+ std::cout << line << std::endl;
+ printline();
+}
+
+
+
+
+
+int RunApp();
+
+
+#endif // OPTION1_H
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/option2.cpp b/Exam/IKT203Exam/Portfolio/Assignment-04/option2.cpp
new file mode 100644
index 0000000..6084da3
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/option2.cpp
@@ -0,0 +1,47 @@
+#include
+#include "option1.h"
+#include "SharedLib.h"
+static constexpr std::string_view AssignmentOption = "Option 1 (Standard): Data Center Network Monitor.";
+
+
+/**
+ * @brief Callback function to process one node.
+ */
+static bool NodeReadCallback(const int aIndex, const int aTotalCount, const std::string& aNode)
+{
+ std::cout << "Loading Node " << (aIndex + 1) << " of " << aTotalCount << ": " << aNode << "\n";
+
+ // Return true to continue reading
+ return true;
+}
+
+/**
+ * @brief Callback function to process one edge.
+ */
+static bool EdgeReadCallback(const int aIndex, const int aTotalCount, const std::string& aFromNode, const std::string& aToNode, float aWeight)
+{
+ std::cout << " Loading Edge " << (aIndex + 1) << " of " << aTotalCount << ": "
+ << aFromNode << " -> " << aToNode << " (Weight: " << aWeight << ")\n";
+
+ // Return true to continue reading
+ return true;
+}
+
+/*
+int RunApp()
+{
+
+ std::cout << AssignmentOption << std::endl;
+
+ // Path to the graph data file
+ std::string filename = "F:\\IKT203\\VisualStudio\\DATA\\city_graph.txt";
+
+ std::cout << "Reading graph from file: " << filename << "\n\n";
+
+ // Call the utility function with both callbacks
+ readGraphFromFile(filename, NodeReadCallback, EdgeReadCallback);
+
+ std::cout << "\nFinished reading graph." << std::endl;
+
+ return 0;
+}*/
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/Assignment-04/option2.h b/Exam/IKT203Exam/Portfolio/Assignment-04/option2.h
new file mode 100644
index 0000000..8c71889
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/Assignment-04/option2.h
@@ -0,0 +1,9 @@
+#pragma once
+
+#ifndef OPTION2_H
+#define OPTION2_H
+/*
+int RunApp();
+*/
+
+#endif // OPTION2_H
diff --git a/Exam/IKT203Exam/Portfolio/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/CMakeLists.txt
new file mode 100644
index 0000000..c8b96cf
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/CMakeLists.txt
@@ -0,0 +1,20 @@
+# CMakeList.txt : Top-level CMake project file, do global configuration
+# and include sub-projects here.
+#
+cmake_minimum_required (VERSION 3.20)
+project ("Portfolio")
+
+# Enable Hot Reload for MSVC compilers if supported.
+if (POLICY CMP0141)
+ cmake_policy(SET CMP0141 NEW)
+ set(CMAKE_MSVC_DEBUG_INFORMATION_FORMAT "$,$>,$<$:EditAndContinue>,$<$:ProgramDatabase>>")
+endif()
+
+# Include sub-projects.
+add_subdirectory(SharedLib)
+# Tell CMake to find and include the first exercise project.
+add_subdirectory(Assignment-01)
+add_subdirectory(Assignment-02)
+add_subdirectory(Assignment-03)
+add_subdirectory(Assignment-04)
+
diff --git a/Exam/IKT203Exam/Portfolio/IKT203_ Final Portfolio Assignment.pdf b/Exam/IKT203Exam/Portfolio/IKT203_ Final Portfolio Assignment.pdf
new file mode 100644
index 0000000..43c9640
Binary files /dev/null and b/Exam/IKT203Exam/Portfolio/IKT203_ Final Portfolio Assignment.pdf differ
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/CMakeLists.txt b/Exam/IKT203Exam/Portfolio/SharedLib/CMakeLists.txt
new file mode 100644
index 0000000..3a208b6
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/CMakeLists.txt
@@ -0,0 +1,44 @@
+# --- Step 1: Create the Library ---
+
+# Define a library target named "SharedLib".
+# We use STATIC because we are using cpp and header files.
+add_library(SharedLib STATIC
+ TPerson.cpp
+ TPerson.h
+ TLinkedList.cpp
+ TLinkedList.h
+ ../Assignment-03/TEmployee.h)
+
+# --- Step 2: Add Header Files to the Library ---
+
+# This command explicitly lists the header files that belong to the library.
+# This helps Visual Studio display them nicely in the Solution Explorer.
+target_sources(SharedLib
+ PUBLIC
+ # You can add more functionalty to SharedLib.h just by adding more definitions in SharedLib.h.
+ SharedLib.h
+ TDoublyLinkedList.h
+ TStack.h
+ TTreeQueue.h
+ Utils.h
+ # Or add other shared files here
+ PRIVATE
+ ReadNames.cpp
+ ReadGraph.cpp
+ ReadSongs.cpp
+ FileReaderUtils.cpp
+ TDoublyLinkedList.cpp
+ TStack.cpp
+ TTreeQueue.cpp
+ Utils.cpp
+)
+
+# --- Step 3: Make Headers "Findable" ---
+
+# This is the most important command here.
+# It tells any other project that links to "SharedLib" to add this
+# directory (CMAKE_CURRENT_SOURCE_DIR) to its list of include paths.
+# This is what allows you to write #include "list.hpp" in your main.cpp.
+# Note: CMAKE_CURRENT_SOURCE_DIR is a built-in variable that points to the directory
+target_include_directories(SharedLib PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
+
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.cpp
new file mode 100644
index 0000000..0fdcb8a
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.cpp
@@ -0,0 +1,30 @@
+#include "FileReaderUtils.h"
+
+int GetRecordCount(const std::string& aHeaderLine)
+{
+ size_t recordPos = aHeaderLine.find("records:=");
+ if (recordPos == std::string::npos)
+ {
+ return 0; // No record count found
+ }
+
+ size_t countStart = recordPos + 9; // Length of "records:="
+
+ // Find the end bracket ']' or a potential semicolon ';'
+ size_t countEnd = aHeaderLine.find_first_of("];", countStart);
+ if (countEnd == std::string::npos)
+ {
+ return 0; // Malformed header
+ }
+
+ std::string countStr = aHeaderLine.substr(countStart, countEnd - countStart);
+ try
+ {
+ // stoi = string to integer
+ return std::stoi(countStr);
+ }
+ catch (const std::exception&)
+ {
+ return 0; // Malformed number
+ }
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.h b/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.h
new file mode 100644
index 0000000..8d000d6
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/FileReaderUtils.h
@@ -0,0 +1,13 @@
+// FileReaderUtils.h
+#pragma once
+#if !defined(FILEREADERUTILS_H)
+#define FILEREADERUTILS_H
+#include
+/**
+ * @brief [Internal] Safely parses the "records:=N" part of a header line.
+ * @param aHeaderLine The line, e.g., "[NODES;records:=11]"
+ * @return The number of records, or 0 if not found.
+ */
+int GetRecordCount(const std::string& aHeaderLine);
+
+#endif // FILEREADERUTILS_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/ReadGraph.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/ReadGraph.cpp
new file mode 100644
index 0000000..69c6e20
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/ReadGraph.cpp
@@ -0,0 +1,109 @@
+#include
+#include
+#include
+#include
+#include "SharedLib.h"
+#include "FileReaderUtils.h"
+
+// --- Enum for the parser's state ---
+enum class EParseState
+{
+ NONE,
+ NODES,
+ EDGES
+};
+
+void readGraphFromFile(const std::string& aFilename, FNodeRead aOnNodeRead, FEdgeRead aOnEdgeRead)
+{
+ if (aFilename.empty()) return;
+
+ std::ifstream file(aFilename);
+ if (!file.is_open())
+ {
+ // Optional: print an error
+ // std::cerr << "Error: Could not open file " << aFilename << std::endl;
+ return;
+ }
+
+ std::string line;
+ EParseState currentState = EParseState::NONE;
+ int totalCount = 0;
+ int currentIndex = 0;
+ bool keepReading = true;
+
+ while (keepReading && std::getline(file, line))
+ {
+ if (line.empty()) continue;
+
+ if (line[0] == '[')
+ {
+ // --- 2. USE THE SHARED FUNCTION ---
+ totalCount = GetRecordCount(line);
+ currentIndex = 0;
+
+ if (line.find("[NODES") != std::string::npos)
+ {
+ currentState = EParseState::NODES;
+ continue;
+ }
+ else if (line.find("[EDGES") != std::string::npos)
+ {
+ currentState = EParseState::EDGES;
+ continue;
+ }
+ // If it's a comment or other header, reset state and count
+ currentState = EParseState::NONE;
+ totalCount = 0;
+ continue;
+ }
+
+ // Process data based on the current state
+ switch (currentState)
+ {
+ case EParseState::NODES:
+ if (aOnNodeRead)
+ {
+ if (!aOnNodeRead(currentIndex, totalCount, line))
+ {
+ keepReading = false;
+ }
+ currentIndex++;
+ }
+ break;
+
+ case EParseState::EDGES:
+ {
+ std::istringstream edgeStream(line);
+ std::string fromNode, toNode, weightStr;
+
+ if (std::getline(edgeStream, fromNode, ';') &&
+ std::getline(edgeStream, toNode, ';') &&
+ std::getline(edgeStream, weightStr))
+ {
+ try
+ {
+ // Use std::stof (string to float) for weight
+ float weight = std::stof(weightStr);
+ if (aOnEdgeRead)
+ {
+ if (!aOnEdgeRead(currentIndex, totalCount, fromNode, toNode, weight))
+ {
+ keepReading = false;
+ }
+ currentIndex++;
+ }
+ }
+ catch (const std::exception&)
+ {
+ // Failed to parse float, skip this line
+ }
+ }
+ break;
+ }
+ case EParseState::NONE:
+ default:
+ break;
+ }
+ }
+ file.close();
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/ReadNames.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/ReadNames.cpp
new file mode 100644
index 0000000..a3407ac
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/ReadNames.cpp
@@ -0,0 +1,55 @@
+#include
+#include
+#include
+#include
+#include "SharedLib.h"
+#include "FileReaderUtils.h"
+
+void readNamesFromFile(const std::string& aFilename, FNameRead aOnNameRead)
+{
+ if (aFilename.empty()) return;
+
+ std::ifstream file(aFilename);
+ if (!file.is_open())
+ {
+ std::cerr << "Error: Could not open file " << aFilename << std::endl;
+ return;
+ }
+
+ std::string line;
+ int totalCount = 0;
+ int currentIndex = 0;
+ bool keepReading = true;
+
+ // --- 1. Read the header line ---
+ if (std::getline(file, line))
+ {
+ // Use our shared helper to get the count
+ totalCount = GetRecordCount(line);
+ }
+
+ // --- 2. Loop through the rest of the file ---
+ while (keepReading && std::getline(file, line))
+ {
+ if (line.empty()) continue;
+
+ std::istringstream nameStream(line);
+ std::string firstName, lastName;
+
+ // Parse "FirstName LastName"
+ if (nameStream >> firstName >> lastName)
+ {
+ if (aOnNameRead)
+ {
+ // Call the callback with all parameters
+ if (!aOnNameRead(currentIndex, totalCount, firstName, lastName))
+ {
+ keepReading = false;
+ }
+ currentIndex++;
+ }
+ }
+ }
+
+ file.close();
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/ReadSongs.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/ReadSongs.cpp
new file mode 100644
index 0000000..6460ae2
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/ReadSongs.cpp
@@ -0,0 +1,60 @@
+#include
+#include
+#include
+#include
+#include "SharedLib.h"
+#include "FileReaderUtils.h" // Include the shared utility
+
+void ReadSongsFromFile(const std::string& aFilename, FSongRead aOnSongRead)
+{
+ if (aFilename.empty()) return;
+
+ std::ifstream file(aFilename);
+ if (!file.is_open())
+ {
+ // std::cerr << "Error: Could not open file " << aFilename << std::endl;
+ return;
+ }
+
+ std::string line;
+ int totalCount = 0;
+ int currentIndex = 0;
+ bool keepReading = true;
+
+ // --- 1. Read the header line ---
+ if (std::getline(file, line))
+ {
+ // Use our shared helper to get the count
+ totalCount = GetRecordCount(line);
+ }
+
+ // --- 2. Loop through the rest of the file (the data lines) ---
+ while (keepReading && std::getline(file, line))
+ {
+ if (line.empty()) continue; // Skip empty lines
+
+ std::istringstream lineStream(line);
+ std::string artist, title, year, genre, source;
+
+ // Parse the five semicolon-separated fields
+ // Artist;Title;Year;Genre;Source
+ if (std::getline(lineStream, artist, ';') &&
+ std::getline(lineStream, title, ';') &&
+ std::getline(lineStream, year, ';') &&
+ std::getline(lineStream, genre, ';') &&
+ std::getline(lineStream, source)) // Last one reads to end of line
+ {
+ if (aOnSongRead)
+ {
+ // Call the callback with all parameters
+ if (!aOnSongRead(currentIndex, totalCount, artist, title, year, genre, source))
+ {
+ keepReading = false;
+ }
+ currentIndex++;
+ }
+ }
+ }
+
+ file.close();
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/SharedLib.h b/Exam/IKT203Exam/Portfolio/SharedLib/SharedLib.h
new file mode 100644
index 0000000..0406827
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/SharedLib.h
@@ -0,0 +1,101 @@
+#pragma once
+#ifndef SHARED_LIB_H
+#define SHARED_LIB_H
+#include
+#include
+#include "../Assignment-03/TAVL.h"
+
+///
+/// Delegate type for processing a name read from a file.
+///
+/// The index of the name (0-based).
+/// The total number of names.
+/// The first name read from the file.
+/// The last name read from the file.
+/// Returns true to continue reading, false to stop.
+typedef bool (*FNameRead)(
+ const int aIndex,
+ const int aTotalCount,
+ const std::string& aFirstName,
+ const std::string& aLastName
+ );
+
+///
+/// Use this function to read names from a specified file and process them using a callback function.
+///
+/// readNamesFromFile
+/// Reads names from a specified file and invokes a callback for each name read.
+/// The path to the file containing names.
+/// A callback function that is called for each name read. It takes two parameters: firstName and lastName. If the callback returns false, the reading process stops.
+/// The first name read from the file.
+/// The last name read from the file.
+/// None.
+void readNamesFromFile(const std::string& aFilename, FNameRead aOnNameRead);
+
+///
+/// Delegate type for processing a node read from the file.
+///
+/// Function pointer type for a callback that processes nodes read from a file.
+/// The index of the node (0-based).
+/// The total number of nodes.
+/// The node std::string.
+/// Returns true to continue reading, false to stop.
+typedef bool (*FNodeRead)(const int aIndex, const int aTotalCount, const std::string& aNode);
+
+///
+/// Delegate type for processing an edge read from the file.
+///
+/// Function pointer type for a callback that processes edges read from a file.
+/// The index of the edge (0-based).
+/// The total number of edges.
+/// The from node std::string.
+/// The to node std::string.
+/// The weight of the edge.
+/// Returns true to continue reading, false to stop.
+typedef bool (*FEdgeRead)(const int aIndex, const int aTotalCount, const std::string& aFromNode, const std::string& aToNode, float aWeight);
+
+///
+/// Use this function to read a graph from a specified file and process its nodes and edges using callback functions.
+///
+/// readGraphFromFile
+///
+/// Reads a graph from a specified file and invokes callbacks for each node and edge read.
+/// All nodes are read first, followed by edges.
+///
+/// The path to the file containing the graph data.
+/// A callback function that is called for each node read. It takes one parameter: the node std::string. If the callback returns false, the reading process stops.
+/// A callback function that is called for each edge read. It takes three parameters: the fromNode std::string, the toNode std::string, and the weight float. If the callback returns false, the reading process stops.
+void readGraphFromFile(const std::string& aFilename, FNodeRead aOnNodeRead, FEdgeRead aOnEdgeRead);
+
+
+///
+/// Delegate type for processing a song read from the file.
+///
+/// The index of the song (0-based).
+/// The total number of songs.
+/// The artist.
+/// The title.
+/// The release year (as a std::string).
+/// The genre.
+/// The source.
+/// Returns true to continue reading, false to stop.
+typedef bool (*FSongRead)(
+ const int aIndex,
+ const int aTotalCount,
+ const std::string& aArtist,
+ const std::string& aTitle,
+ const std::string& aYear,
+ const std::string& aGenre,
+ const std::string& aSource
+ );
+
+///
+/// Reads song data from a file and processes them using a callback.
+/// This function automatically skips the "records:=" header.
+///
+/// The path to the file (e.g., "songs.txt").
+/// The callback function called for each song.
+void ReadSongsFromFile(const std::string& aFilename, FSongRead aOnSongRead);
+
+
+#endif // SHARED_LIB_H
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.cpp
new file mode 100644
index 0000000..bff1e25
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.cpp
@@ -0,0 +1,128 @@
+#include "TDoublyLinkedList.h"
+#include
+#include "SharedLib.h"
+
+
+TDoublyLinkedList::~TDoublyLinkedList()
+{
+ const Node* cur = head;
+ while (cur) {
+ const Node* next = cur->GetNext();
+ delete cur;
+ cur = next;
+ }
+ head = tail = nullptr;
+ size = 0;
+}
+
+// Append a new line at the end of the list.
+void TDoublyLinkedList::Append(const std::string& line)
+{
+ auto* newNode = new Node(line);
+ if (size == 0)
+ head = tail = newNode;
+ else {
+ newNode->SetPrev(tail);
+ tail->SetNext(newNode);
+ tail = newNode;
+ }
+ size++;
+}
+
+// Insert a new line at the beginning.
+void TDoublyLinkedList::Prepend(const std::string& line)
+{
+ auto* newNode = new Node(line);
+ if (size == 0)
+ head = tail = newNode;
+ else {
+ newNode->SetNext(head);
+ head->SetPrev(newNode);
+ head = newNode;
+ }
+ size++;
+}
+
+TDoublyLinkedList::Node* TDoublyLinkedList::NavigateToNode(const int index) const
+{
+ if (index < 0 || index >= size)
+ return nullptr;
+
+ auto* node = head;
+
+ for (int i = 0; i < index; i++)
+ node = node->GetNext();
+
+ return node;
+}
+
+// Removes the node at the given index and updates head/tail if needed.
+void TDoublyLinkedList::Remove(const int index)
+{
+ auto* node = NavigateToNode(index);
+ if (!node)
+ return;
+
+ if (node->GetPrev())
+ node->GetPrev()->SetNext(node->GetNext());
+ else
+ head = node->GetNext();
+ if (node->GetNext())
+ node->GetNext()->SetPrev(node->GetPrev());
+ else
+ tail = node->GetPrev();
+
+ delete node;
+ size--;
+}
+
+std::string TDoublyLinkedList::GetAtIndex(const int index) const
+{
+ const auto* node = NavigateToNode(index);
+ return node ? node->GetLine() : "Error, line does not exist\n";
+}
+
+void TDoublyLinkedList::InsertAtIndex(const int index, const std::string &line)
+{
+ if (index < 0 || index > size) {
+ std::cout << "========\nIndex doesn't exist\n========\n" << std::endl;
+ return;
+ }
+ if (index == 0)
+ {
+ Prepend(line);
+ return;
+ }
+ if (index == size)
+ {
+ Append(line);
+ return;
+ }
+ Node* cur = head;
+ for (int i = 0; i < index; i++)
+ cur = cur->GetNext();
+ Node* newNode = new Node(line);
+ Node* prev = cur->GetPrev();
+
+ newNode->SetPrev(prev);
+ newNode->SetNext(cur);
+
+ prev->SetNext(newNode);
+ cur->SetPrev(newNode);
+
+ size++;
+}
+
+
+int TDoublyLinkedList::GetSize() const
+{
+ return size;
+}
+
+
+
+
+
+
+
+
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.h b/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.h
new file mode 100644
index 0000000..04746ad
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TDoublyLinkedList.h
@@ -0,0 +1,72 @@
+#ifndef TDOUBLYLINKEDLIST_H
+#define TDOUBLYLINKEDLIST_H
+#include
+#include
+
+
+// Doubly linked list used to store document lines.
+// Supports insertion, removal, and indexed access.
+// Chosen because it allows efficient updates in the middle of the document.
+class TDoublyLinkedList {
+
+private:
+ // Internal node storing a single line of text
+ // and links to previous and next nodes.
+ struct Node {
+ std::string line;
+ Node* next;
+ Node* prev;
+ explicit Node(std::string text) : line(std::move(text)), next(nullptr), prev(nullptr) {}
+
+ void SetNext(Node* node)
+ {
+ this->next = node;
+ }
+ void SetPrev(Node* node)
+ {
+ this->prev = node;
+ }
+ [[nodiscard]] Node* GetPrev() const
+ {
+ return this->prev;
+ }
+ [[nodiscard]] Node* GetNext() const
+ {
+ return this->next;
+ }
+ [[nodiscard]] std::string GetLine() const
+ {
+ return line;
+ }
+
+ };
+
+ Node* head;
+ Node* tail;
+ int size;
+
+
+public:
+ TDoublyLinkedList() : head(nullptr), tail(nullptr), size(0) {}
+ ~TDoublyLinkedList();
+
+ void Append(const std::string &line);
+ void Prepend(const std::string& line);
+
+ // Returns pointer to node at given index.
+ // Linear traversal; used internally by Remove and InsertAtIndex.
+ [[nodiscard]] Node* NavigateToNode(int index) const;
+
+ // Removes a node at the given index.
+ // Updates links and frees the removed node.
+ void Remove(int index);
+
+ // Returns the text stored at the given index.
+ // Uses NavigateToNode internally.
+ [[nodiscard]] std::string GetAtIndex(int index) const;
+ void InsertAtIndex(int index, const std::string &line);
+ [[nodiscard]] int GetSize() const;
+};
+
+
+#endif //TDOUBLYLINKEDLIST_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.cpp
new file mode 100644
index 0000000..26b3f4c
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.cpp
@@ -0,0 +1,182 @@
+#include "TLinkedList.h"
+#include
+
+TLinkedList::~TLinkedList()
+{
+ Node* cur = head;
+ while (cur) {
+ Node* next = cur->next;
+ delete cur;
+ cur = next;
+ }
+ head = nullptr;
+ tail = nullptr;
+ size = 0;
+}
+
+void TLinkedList::Append(const TPerson& person)
+{
+ Node* newNode = new Node(person);
+ if (size == 0) {
+ head = tail = newNode;
+ } else {
+ tail->next = newNode;
+ tail = newNode;
+ }
+ size++;
+}
+
+void TLinkedList::Prepend(const TPerson& person)
+{
+ Node* newNode = new Node(person);
+ if (size == 0) {
+ head = tail = newNode;
+ } else {
+ newNode->next = head;
+ head = newNode;
+ }
+ size++;
+}
+
+void TLinkedList::InsertAtIndex(const int index, const TPerson& person)
+{
+ if (index < 0 || index > size) {
+ std::cout << "Index out of range\n";
+ return;
+ }
+
+ if (index == 0) {
+ Prepend(person);
+ return;
+ }
+ if (index == size) {
+ Append(person);
+ return;
+ }
+
+ Node* prev = head;
+ for (int i = 0; i < index - 1; ++i)
+ prev = prev->next;
+
+ Node* newNode = new Node(person);
+ newNode->next = prev->next;
+ prev->next = newNode;
+ size++;
+}
+
+void TLinkedList::Remove(const int index)
+{
+ if (index < 0 || index >= size)
+ return;
+
+ if (index == 0) {
+ const Node* oldHead = head;
+ head = head->next;
+ if (size == 1)
+ tail = nullptr;
+ delete oldHead;
+ size--;
+ return;
+ }
+
+ Node* prev = head;
+ for (int i = 0; i < index - 1; ++i)
+ prev = prev->next;
+
+ const Node* toDelete = prev->next;
+ prev->next = toDelete->next;
+ if (toDelete == tail)
+ tail = prev;
+ delete toDelete;
+ size--;
+}
+
+TPerson TLinkedList::GetAtIndex(const int index) const
+{
+ if (index < 0 || index >= size) {
+ std::cout << "Index out of range\n";
+ return {};
+ }
+
+ Node* cur = head;
+ for (int i = 0; i < index; ++i)
+ cur = cur->next;
+
+ return cur->person;
+}
+
+void TLinkedList::MergeSortSplit(Node *source, Node **front, Node **back)
+{
+ if (source == nullptr || source->next == nullptr) {
+ *front = source;
+ *back = nullptr;
+ return;
+ }
+
+ Node* slow = source;
+ const Node* fast = source->next;
+
+ while (fast != nullptr) {
+ fast = fast->next;
+ if (fast != nullptr) {
+ slow = slow->next;
+ fast = fast->next;
+ }
+ }
+
+ *front = source;
+ *back = slow->next;
+ slow->next = nullptr;
+}
+
+TLinkedList::Node *TLinkedList::MergeList(Node *a, Node *b)
+{
+ if (a == nullptr)
+ return b;
+ if (b == nullptr)
+ return a;
+
+ Node* result = nullptr;
+
+ if (a->person < b->person) {
+ result = a;
+ result->next = MergeList(a->next, b);
+ }
+ else {
+ result = b;
+ result->next = MergeList(a, b->next);
+ }
+ return result;
+}
+
+// Time complexity O(n log n) at all times
+// Does NOT sort in place, so more memory is needed to complete
+TLinkedList::Node *TLinkedList::MergeSort(Node *head)
+{
+ if (head == nullptr || head->next == nullptr)
+ return head;
+
+ Node* front;
+ Node* back;
+
+ MergeSortSplit(head, &front, &back);
+
+ front = MergeSort(front);
+ back = MergeSort(back);
+ return MergeList(front, back);
+}
+
+// Stable merge sort on the linked list.
+// Time complexity: O(n log n), requires extra pointers but no extra arrays.
+void TLinkedList::Sort()
+{
+ this->head = MergeSort(head);
+
+ Node* cur = this->head;
+ tail = nullptr;
+ while (cur) {
+ if (cur->next == nullptr)
+ tail = cur;
+ cur = cur->next;
+ }
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.h b/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.h
new file mode 100644
index 0000000..8ba202b
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TLinkedList.h
@@ -0,0 +1,59 @@
+#ifndef IKT203_COURSE_ASSIGNMENTS_TLINKEDLIST_H
+#define IKT203_COURSE_ASSIGNMENTS_TLINKEDLIST_H
+
+#include "TPerson.h"
+
+// Singly linked list of TPerson, used for the guest and employee manifests.
+// Owns all its Node objects and frees them in the destructor.
+// Supports append, prepend, insert, remove, indexed access, and merge-sort.
+class TLinkedList {
+
+
+ private:
+ struct Node {
+ TPerson person; // stored by value
+ Node* next;
+ explicit Node(const TPerson& p) : person(p), next(nullptr) {}
+
+ void setNext(Node* n)
+ {
+ this->next = n;
+ }
+
+ [[nodiscard]] static Node* GetNext(const Node* n)
+ {
+ return n->next;
+ }
+
+ [[nodiscard]] static TPerson GetPerson(Node* n)
+ {
+ return n->person;
+ }
+ };
+ Node* head;
+ Node* tail;
+ int size;
+public:
+ TLinkedList() : head(nullptr), tail(nullptr), size(0) {}
+ ~TLinkedList();
+
+ void Append(const TPerson& person);
+ void Prepend(const TPerson& person);
+ void InsertAtIndex(int index, const TPerson& person);
+ void Remove(int index);
+ [[nodiscard]] TPerson GetAtIndex(int index) const;
+ [[nodiscard]] int GetSize() const { return size; }
+ static void MergeSortSplit(Node* source, Node** front, Node** back);
+ static Node* MergeList(Node*, Node*);
+ static Node* MergeSort(Node*);
+ void Sort();
+
+
+
+
+
+
+};
+
+
+#endif //IKT203_COURSE_ASSIGNMENTS_TLINKEDLIST_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.cpp
new file mode 100644
index 0000000..9a69de8
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.cpp
@@ -0,0 +1,11 @@
+#include "TPerson.h"
+
+#include
+#include "Utils.h"
+
+
+TPerson::TPerson() : firstName("N/A"),lastName("N/A"), status(GUEST), cabinSize(Utils::RandomInt(1, 4)) {}
+
+TPerson::TPerson(std::string f, std::string l, const ENumStatus s) : firstName(std::move(f)), lastName(std::move(l)), status(s), cabinSize(Utils::RandomInt(1, 4)) {}
+
+
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.h b/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.h
new file mode 100644
index 0000000..05861f7
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TPerson.h
@@ -0,0 +1,38 @@
+#ifndef IKT203_COURSE_ASSIGNMENTS_TPERSON_H
+#define IKT203_COURSE_ASSIGNMENTS_TPERSON_H
+#include
+
+#include "Utils.h"
+
+enum ENumStatus {
+ GUEST,
+ EMPLOYEE
+};
+
+// Represents one person on the cruise ship.
+// - 'status' tells us if they're a GUEST or EMPLOYEE
+// - 'cabinSize' is random in [1, 4] and used for cabin grouping
+struct TPerson {
+ std::string firstName;
+ std::string lastName;
+ ENumStatus status;
+ int cabinSize{};
+
+ TPerson();
+ TPerson(std::string , std::string , ENumStatus);
+ ~TPerson() = default;
+
+ // Comparison for alphabetical sorting:
+ // primary key: lastName, secondary key: firstName.
+ bool operator<(const TPerson& other) const
+ {
+ if (lastName < other.lastName) return true;
+ if (lastName > other.lastName) return false;
+ // same last name â compare first name
+ return firstName < other.firstName;
+ }
+
+};
+
+
+#endif //IKT203_COURSE_ASSIGNMENTS_TPERSON_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TStack.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/TStack.cpp
new file mode 100644
index 0000000..6f957c1
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TStack.cpp
@@ -0,0 +1,36 @@
+#include "TStack.h"
+#include
+
+void TStack::Push(const TAction& action)
+{
+ if (top >= STACK_MAX_SIZE)
+ throw std::overflow_error("Stack overflow");
+ event[top++] = action;
+}
+
+TStack::TAction TStack::Pop()
+{
+ if (top == 0)
+ throw std::underflow_error("Stack empty");
+ return event[--top];
+}
+
+TStack::TAction TStack::Peek() const
+{
+ if (top == 0)
+ throw std::underflow_error("Stack empty");
+ return event[top - 1];
+}
+
+bool TStack::IsEmpty() const
+{
+ return top == 0;
+}
+
+void TStack::Clear()
+{
+ for (int i = 0; i < top; i++) {
+ this->Pop();
+ }
+}
+
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TStack.h b/Exam/IKT203Exam/Portfolio/SharedLib/TStack.h
new file mode 100644
index 0000000..4315f29
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TStack.h
@@ -0,0 +1,41 @@
+#ifndef TSTACK_H
+#define TSTACK_H
+
+#define STACK_MAX_SIZE 100
+#include
+
+
+enum EnumActionType {
+ INSERT,
+ DELETE
+};
+
+// Simple fixed-size stack used for undo/redo.
+// Stores actions describing line insert/delete operations.
+class TStack {
+private:
+ // Describes a single text-edit action.
+ // 'action' indicates INSERT or DELETE,
+ // 'text' stores the affected line, and 'index' is the line position.
+ struct TAction {
+ EnumActionType action;
+ std::string text;
+ int index;
+ };
+
+ TAction event[STACK_MAX_SIZE]{};
+ int top = 0;
+
+public:
+ TStack() = default;
+ ~TStack() = default;
+ void Push(const TAction& action); // Adds a new action to the top of the stack.
+ TAction Pop(); // Removes and returns the most recent action.
+ [[nodiscard]] TAction Peek() const;
+ [[nodiscard]] bool IsEmpty() const;
+ void Clear();
+
+};
+
+
+#endif //TSTACK_H
\ No newline at end of file
diff --git a/Stacks&Queues/TQueue.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.cpp
similarity index 58%
rename from Stacks&Queues/TQueue.cpp
rename to Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.cpp
index cb00bd5..aafad23 100644
--- a/Stacks&Queues/TQueue.cpp
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.cpp
@@ -1,55 +1,47 @@
-#include "TQueue.h"
+#include "TTreeQueue.h"
+
#include
-// Time and space O(1) - only adds to the end of the queue and wraps around when needed
-void TQueue::Enqueue(const int item)
+void TTreeQueue::Enqueue(const std::string& text)
{
if (IsFull())
throw std::overflow_error("Queue Overflow");
- queue[tail] = item;
+ queue[tail] = text;
tail = (tail + 1) % MAX_SIZE;
count++;
}
-// Both O(1)
-int TQueue::Dequeue()
+std::string TTreeQueue::Dequeue()
{
if (IsEmpty())
throw std::underflow_error("Empty Queue");
- const int item = queue[head];
+ const std::string item = queue[head];
head = (head + 1) % MAX_SIZE;
count--;
return item;
}
-// Both O(1)
-int TQueue::Peek() const
+std::string TTreeQueue::Peek() const
{
if (IsEmpty())
throw std::underflow_error("Empty Queue");
return queue[head];
}
-// Both O(1)
-bool TQueue::IsEmpty() const
+bool TTreeQueue::IsEmpty() const
{
return count == 0;
}
-bool TQueue::IsFull() const
+bool TTreeQueue::IsFull() const
{
return count == MAX_SIZE;
}
-int TQueue::GetTail() const
+int TTreeQueue::GetTail() const
{
if (IsEmpty())
throw std::underflow_error("Empty Queue");
return tail;
}
-
-
-
-
-
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.h b/Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.h
new file mode 100644
index 0000000..e73b8fb
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/TTreeQueue.h
@@ -0,0 +1,31 @@
+#ifndef TQUEUE_H
+#define TQUEUE_H
+#define MAX_SIZE 100
+
+#include "TDoublyLinkedList.h"
+
+
+// Circular array-based queue implementation.
+// Used in Cat 1 to store print jobs (each job is a full document snapshot).
+// Demonstrates FIFO behavior through enqueue/dequeue operations.
+class TTreeQueue {
+private:
+ std::string queue[MAX_SIZE];
+ int head = 0;
+ int tail = 0;
+ int count = 0;
+
+public:
+ TTreeQueue() = default;
+ ~TTreeQueue() = default;
+
+ void Enqueue(const std::string& text); // Adds a new job at the tail of the queue.
+ std::string Dequeue(); // Removes and returns the next job in FIFO order.
+ [[nodiscard]] int GetTail() const;
+ [[nodiscard]] std::string Peek() const;
+ [[nodiscard]] bool IsEmpty() const;
+ [[nodiscard]] bool IsFull() const;
+};
+
+
+#endif //TQUEUE_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/Utils.cpp b/Exam/IKT203Exam/Portfolio/SharedLib/Utils.cpp
new file mode 100644
index 0000000..880141e
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/Utils.cpp
@@ -0,0 +1,170 @@
+#include "Utils.h"
+#include "TDoublyLinkedList.h"
+#include "TStack.h"
+#include "TPerson.h"
+#include
+#include
+#include
+
+// Displays the main menu and reads user choice.
+int Utils::Choice()
+{
+ std::cout << "========\n1. Add line\n2. Remove line\n3. View current1 document\n4. Print queue\n5. Process print job\n6. Undo\n7. Redo\n0. Exit"
+ "\n\nChoice: ";
+ int choice;
+ std::cin >> choice;
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ return choice;
+}
+
+// Inserts a new line into the document.
+// Records the action into the undo stack.
+// 'index' determines insert location; defaults to end of document.
+int Utils::Insert(TDoublyLinkedList &document, TStack &undoStack, TStack &redoStack, int index)
+{
+ for (int i = 0; i < document.GetSize(); i++) {
+ std::cout << i + 1 << ". " << document.GetAtIndex(i) << std::endl;
+ }
+ if (document.GetSize() > 0)
+ {
+ std::cout << "Enter the line number where you want to insert the line" <> index)) {
+ std::cin.clear();
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ std::cout << "========\nIndex must be a number\n========\n\n" << std::endl;
+ return index;
+ }
+
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ }
+ if (document.GetSize() < 1)
+ index = 1;
+
+ std::cout << "Enter the text" <> index)) {
+ std::cin.clear();
+ std::cin.ignore(std::numeric_limits::max(), '\n');
+ std::cout << "========\nIndex must be a number\n========\n\n" << std::endl;
+ return index;
+ } std::cin.ignore(std::numeric_limits::max(), '\n');
+ const std::string deletedLine = document.GetAtIndex(index-1);
+ document.Remove(index-1);
+ undoStack.Push({DELETE, deletedLine, index-1});
+ if (!redoStack.IsEmpty()) {
+ redoStack.Clear();
+ }
+ return index;
+}
+
+int Utils::RandomInt(const int min, const int max)
+{
+ static bool isSeeded = false;
+ if (!isSeeded) {
+ std::srand(static_cast(std::time(nullptr))); //<---- not the "best" random seeding available
+ isSeeded = true; // but sufficient for this use case
+ }
+
+ if (max <= min)
+ return 0;
+
+ return min + rand() % (max - min + 1); // <---- Limited randomness, but again
+} // sufficient for this use case
+
+// Comparison used for cabin grouping (QuickSort):
+// 1) cabinSize ascending
+// 2) lastName alphabetical
+bool Utils::CompareLastnames(const TPerson *a, const TPerson *b)
+{
+ if (a->cabinSize < b->cabinSize)
+ return true;
+ if (a->cabinSize > b->cabinSize)
+ return false;
+ return a->lastName < b->lastName;
+}
+
+
+int Utils::Partition(TPerson **arr, const int startIndex, const int endIndex)
+{
+ TPerson *pivot = arr[endIndex];
+ int i = startIndex - 1;
+
+ for (int j = startIndex; j < endIndex; j++) {
+ if (CompareLastnames(arr[j], pivot)) {
+ i++;
+ std::swap(arr[i], arr[j]);
+ }
+ }
+
+
+ std::swap(arr[i + 1], arr[endIndex]);
+ return i + 1;
+}
+
+// QuickSort on an array of TPerson* using CompareLastnames:
+// - Average time: O(n log n)
+// - Worst case: O(n^2) if pivot choices are bad
+// - Sorts in-place (no extra arrays)
+void Utils::QuickSort(TPerson** arr, const int low, const int high)
+{
+ if (low < high) {
+ int p = Partition(arr, low, high);
+ QuickSort(arr, low, p - 1);
+ QuickSort(arr, p + 1, high);
+ }
+}
+
+// Binary search on an alphabetically sorted array of TPerson* (by lastName, then firstName).
+// Primary search key: surname. If no surname match is found, falls back to linear scan on firstName.
+int Utils::BinarySearch(TPerson** arr, int p1, int p2, const std::string &target)
+{
+ const int origStart = p1;
+ const int origEnd = p2;
+
+
+ while (p1 <= p2) {
+ const int newP = (p1 + p2) / 2;
+ std::string currentFirst = arr[newP]->firstName;
+ std::string currentLast = arr[newP]->lastName;
+
+ if (target == currentFirst || target == currentLast)
+ return newP;
+
+ if (target > currentLast)
+ p1 = newP + 1;
+
+ else
+ p2 = newP - 1;
+ }
+
+ // Fallback linear scan for first names if no last name match
+ for (int i = origStart; i <= origEnd; i++) {
+ if (arr[i]->firstName == target)
+ return i;
+ }
+ return -1;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Portfolio/SharedLib/Utils.h b/Exam/IKT203Exam/Portfolio/SharedLib/Utils.h
new file mode 100644
index 0000000..febdcae
--- /dev/null
+++ b/Exam/IKT203Exam/Portfolio/SharedLib/Utils.h
@@ -0,0 +1,24 @@
+#ifndef UTILS_H
+#define UTILS_H
+#include "TDoublyLinkedList.h"
+#include "TPerson.h"
+#include "TStack.h"
+
+struct TPerson;
+
+class Utils {
+ public:
+ static int Choice();
+ static int Insert(TDoublyLinkedList &document, TStack &undoStack, TStack &redoStack, int index);
+ static void PrintList(const TDoublyLinkedList &document);
+ static int RemoveLine(TDoublyLinkedList &document, TStack &undoStack, TStack &redoStack, int index);
+ static int RandomInt(int, int);
+ static int Partition(TPerson** arr, int startIndex, int endIndex);
+ static void QuickSort(TPerson**, int, int);
+ static bool CompareLastnames(const TPerson*, const TPerson*);
+ static int BinarySearch(TPerson**, int, int, const std::string&);
+ static int CountMatches(TPerson**, int, const std::string&);
+};
+
+
+#endif //PART1_UTILS_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/CMakeLists.txt b/Exam/IKT203Exam/Submissions/CMakeLists.txt
new file mode 100644
index 0000000..9f5ad33
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/CMakeLists.txt
@@ -0,0 +1,19 @@
+# CMakeList.txt : Top-level CMake project file, do global configuration
+# and include sub-projects here.
+#
+cmake_minimum_required (VERSION 3.20)
+
+# Enable Hot Reload for MSVC compilers if supported.
+if (POLICY CMP0141)
+ cmake_policy(SET CMP0141 NEW)
+ set(CMAKE_MSVC_DEBUG_INFORMATION_FORMAT "$,$>,$<$:EditAndContinue>,$<$:ProgramDatabase>>")
+endif()
+
+project ("Exercises")
+
+# Include sub-projects.
+add_subdirectory ("Submission-01")
+add_subdirectory ("Submission-02")
+add_subdirectory ("Submission-03")
+add_subdirectory ("Submission-04")
+add_subdirectory ("Submission-05")
diff --git a/Exam/IKT203Exam/Submissions/Submission-01/CMakeLists.txt b/Exam/IKT203Exam/Submissions/Submission-01/CMakeLists.txt
new file mode 100644
index 0000000..e72a1e6
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-01/CMakeLists.txt
@@ -0,0 +1,13 @@
+# CMakeList.txt : CMake project for Submission-01, include source and define
+# project specific logic here.
+#
+
+# Add source to this project's executable.
+add_executable (Submission-01 "main.cpp" "main.h")
+target_link_libraries(Submission-01 PRIVATE LibExample)
+
+if (CMAKE_VERSION VERSION_GREATER 3.20)
+ set_property(TARGET Submission-01 PROPERTY CXX_STANDARD 20)
+endif()
+
+# TODO: Add tests and install targets if needed.
diff --git a/Exam/IKT203Exam/Submissions/Submission-01/main.cpp b/Exam/IKT203Exam/Submissions/Submission-01/main.cpp
new file mode 100644
index 0000000..d1921ec
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-01/main.cpp
@@ -0,0 +1,309 @@
+// Submission-01.cpp : Defines the entry point for the application.
+//
+
+#include "main.h"
+#include
+
+
+
+// Movie class with bitwise genre flags
+enum EGenreFlags {
+ Action = 0x0001,
+ Comedy = 0x0002,
+ Drama = 0x0004,
+ Horror = 0x0008,
+ SciFi = 0x0010,
+ Romance = 0x0020,
+ Documentary = 0x0040,
+ Thriller = 0x0080,
+ Crime = 0x0100,
+ Fantasy = 0x0200,
+ Animation = 0x0400,
+ Adventure = 0x0800
+};
+
+static std::string GenreFlagsToString(int genreFlags) {
+ std::string result;
+ if (genreFlags & EGenreFlags::Action) result += "Action ";
+ if (genreFlags & EGenreFlags::Comedy) result += "Comedy ";
+ if (genreFlags & EGenreFlags::Drama) result += "Drama ";
+ if (genreFlags & EGenreFlags::Horror) result += "Horror ";
+ if (genreFlags & EGenreFlags::SciFi) result += "SciFi ";
+ if (genreFlags & EGenreFlags::Romance) result += "Romance ";
+ if (genreFlags & EGenreFlags::Documentary) result += "Documentary ";
+ if (genreFlags & EGenreFlags::Thriller) result += "Thriller ";
+ if (genreFlags & EGenreFlags::Crime) result += "Crime ";
+ if (genreFlags & EGenreFlags::Fantasy) result += "Fantasy ";
+ if (genreFlags & EGenreFlags::Animation) result += "Animation ";
+ if (genreFlags & EGenreFlags::Adventure) result += "Adventure ";
+ return result.empty() ? "None" : result;
+}
+
+// Movie class definition
+class TMovie {
+private:
+ std::string title;
+ std::string director;
+ int year;
+ int genreFlags; // Bitwise combination of EGenreFlags
+ float rating; // Scale from 0.0 to 10.0
+
+public:
+ TMovie(std::string t, std::string d, int y, int g, float r)
+ : title(t), director(d), year(y), genreFlags(g), rating(r) {}
+ void PrintInfo() const {
+ std::cout << "Title: " << title << "\nDirector: " << director
+ << "\nYear: " << year << "\nGenres: " << GenreFlagsToString(genreFlags)
+ << "\nRating: " << rating << "/10\n";
+ }
+ std::string GetTitle() const { return title; }
+ std::string GetDirector() const { return director; }
+ int GetYear() const { return year; }
+ float GetRating() const { return rating; }
+ int GetGenreFlags() const { return genreFlags; }
+ bool HasGenre(EGenreFlags genre) const {
+ return (genreFlags & genre) != 0;
+ }
+};
+
+typedef bool (*FCheckMovie)(TMovie*, void*);
+typedef void (*FMovieIndex)(TMovie*, int);
+
+// Doubly Linked List TMovieNode definition
+struct TMovieNode {
+ TMovie* movie;
+ TMovieNode* next;
+ TMovieNode* prev;
+ TMovieNode(TMovie* m) : movie(m), next(nullptr), prev(nullptr) {}
+};
+
+// Doubly Linked List class definition with dummy node, head, and tail O(1) operations
+class TMovieList {
+ private:
+ TMovieNode* head; // Always points to dummy node
+ TMovieNode* tail;
+ int size;
+
+ // Helper function to get node at index
+ TMovieNode* InternalGetAtIndex(int aIndex) {
+ if (aIndex < 0 || aIndex >= size) return nullptr;
+ TMovieNode* current;
+ // Optimize traversal direction, if index is in the first half, start from head, else from tail
+ if (aIndex < size / 2) {
+ current = head->next; // Start from the beginning
+ for (int i = 0; i < aIndex; i++) {
+ current = current->next;
+ }
+ }
+ else {
+ current = tail; // Start from the end
+ for (int i = size - 1; i > aIndex; i--) {
+ current = current->prev;
+ }
+ }
+ return current;
+ }
+
+public:
+ TMovieList() {
+ head = new TMovieNode(nullptr); // Dummy node
+ tail = head; // Initially, tail is the same as head
+ size = 0;
+ }
+ ~TMovieList() {
+ Clear();
+ delete head; // Delete dummy node
+ }
+ void Clear() {
+ TMovieNode* current = head->next; // Start from the first real node
+ while (current) {
+ TMovieNode* toDelete = current;
+ current = current->next;
+ delete toDelete->movie;
+ delete toDelete;
+ }
+ head->next = nullptr;
+ tail = head; // Reset tail to dummy node
+ size = 0;
+ }
+
+ // Insertion at the end O(1)
+ void Append(TMovie* aMovie) {
+ TMovieNode* newNode = new TMovieNode(aMovie);
+ newNode->prev = tail;
+ tail->next = newNode;
+ tail = newNode;
+ size++;
+ }
+
+ // Prepend at the beginning O(1)
+ void Prepend(TMovie* aMovie) {
+ TMovieNode* newNode = new TMovieNode(aMovie);
+ newNode->next = head->next;
+ newNode->prev = head;
+ if (head->next) {
+ head->next->prev = newNode;
+ } else {
+ tail = newNode; // If list was empty, update tail
+ }
+ head->next = newNode;
+ size++;
+ }
+
+ // GetAtIndex O(n) check direction to optimize
+ TMovie* GetAtIndex(int aIndex) {
+ return InternalGetAtIndex(aIndex)->movie;
+ }
+
+ // Remove at index O(n) use GetAtIndex to find node
+ bool RemoveAtIndex(int aIndex) {
+ if (aIndex < 0 || aIndex >= size) return false;
+ TMovieNode* toDelte = InternalGetAtIndex(aIndex);
+ if (!toDelte) return false;
+ if (toDelte->prev) {
+ toDelte->prev->next = toDelte->next;
+ }
+ if (toDelte->next) {
+ toDelte->next->prev = toDelte->prev;
+ } else {
+ tail = toDelte->prev; // Update tail if last node is removed
+ }
+ delete toDelte->movie;
+ delete toDelte;
+ size--;
+ return true;
+ }
+
+ // Reverse the list O(n)
+ void Reverse() {
+ TMovieNode* current = head->next;
+ TMovieNode* prev = nullptr;
+ tail = head->next;
+ while (current) {
+ TMovieNode* nextNode = current->next;
+ current->next = prev;
+ current->prev = nextNode;
+ prev = current;
+ current = nextNode;
+ }
+ head->next = prev;
+ if (prev) {
+ prev->prev = head;
+ }
+ }
+
+ // SearchFor O(n)
+ TMovie* SearchFor(FCheckMovie aCheckFunc, void* aUserData) {
+ TMovieNode* current = head->next;
+ while (current) {
+ if (aCheckFunc(current->movie, aUserData)) {
+ return current->movie;
+ }
+ current = current->next;
+ }
+ return nullptr;
+ }
+
+ // Every movie in the list O(n)
+ void Every(FMovieIndex aIndexFunc) {
+ TMovieNode* current = head->next;
+ int index = 0;
+ while (current) {
+ aIndexFunc(current->movie, index);
+ current = current->next;
+ index++;
+ }
+ }
+
+};
+
+using namespace std;
+
+static void PrintNode(std::string* data, int index) {
+ cout << "Node " << index << ": " << *data << endl;
+}
+
+static bool CheckMovieByTitle(TMovie* movie, void* title) {
+ return movie->GetTitle() == *(static_cast(title));
+}
+
+static bool CheckMovieByDirector(TMovie* movie, void* director) {
+ return movie->GetDirector() == *(static_cast(director));
+}
+
+static bool FindAllMovieByGenre(TMovie* movie, void* genre) {
+ if(movie->HasGenre(*(static_cast(genre)))) {
+ movie->PrintInfo();
+ std::cout << "-------------------" << std::endl;
+ }
+ // Always return false to continue searching
+ return false;
+}
+
+
+int main()
+{
+
+ std::cout << "--- Submission 1: Linked List ---" << std::endl;
+
+ // Create a movie list
+ TMovieList movieList;
+ // Add some movies
+ movieList.Append(new TMovie("Inception", "Christopher Nolan", 2010, EGenreFlags::Action | EGenreFlags::SciFi, 8.8f));
+ movieList.Append(new TMovie("The Godfather", "Francis Ford Coppola", 1972, EGenreFlags::Crime | EGenreFlags::Drama, 9.2f));
+ movieList.Prepend(new TMovie("Toy Story", "John Lasseter", 1995, EGenreFlags::Animation | EGenreFlags::Adventure | EGenreFlags::Comedy, 8.3f));
+ movieList.Append(new TMovie("The Dark Knight", "Christopher Nolan", 2008, EGenreFlags::Action | EGenreFlags::Crime | EGenreFlags::Drama, 9.0f));
+ // Print movie info
+ for (int i = 0; i < 3; i++) {
+ TMovie* movie = movieList.GetAtIndex(i);
+ if (movie) {
+ movie->PrintInfo();
+ std::cout << "-------------------" << std::endl;
+ }
+ }
+ std::cout << std::endl;
+ // Wait for user input to proceed
+ std::cout << "Press Enter to continue..." << std::endl;
+ std::cin.get();
+
+ // Search for a movie by title
+ std::string searchTitle = "Inception";
+ TMovie* foundMovie = movieList.SearchFor(CheckMovieByTitle, &searchTitle);
+ if (foundMovie) {
+ std::cout << "Found movie by title '" << searchTitle << "':" << std::endl;
+ foundMovie->PrintInfo();
+ } else {
+ std::cout << "Movie with title '" << searchTitle << "' not found." << std::endl;
+ }
+ std::cout << "-------------------" << std::endl;
+ std::cout << std::endl;
+
+ // Search for a movie by director
+ std::string searchDirector = "John Lasseter";
+ foundMovie = movieList.SearchFor(CheckMovieByDirector, &searchDirector);
+ if (foundMovie) {
+ std::cout << "Found movie by director '" << searchDirector << "':" << std::endl;
+ foundMovie->PrintInfo();
+ } else {
+ std::cout << "Movie with director '" << searchDirector << "' not found." << std::endl;
+ }
+ std::cout << "-------------------" << std::endl;
+ std::cout << std::endl;
+
+ // Find all movies in the Action genre
+ EGenreFlags searchGenre = EGenreFlags::Action;
+ std::cout << "Movies in the Action genre:" << std::endl;
+ movieList.SearchFor(FindAllMovieByGenre, &searchGenre);
+ std::cout << std::endl;
+
+ // Reverse the list
+ movieList.Reverse();
+ std::cout << "Movies after reversing the list:" << std::endl;
+ movieList.Every([](TMovie* movie, int index) {
+ std::cout << "Index " << index << ":" << std::endl;
+ movie->PrintInfo();
+ std::cout << "-------------------" << std::endl;
+ });
+
+ return 0;
+}
diff --git a/Exam/IKT203Exam/Submissions/Submission-01/main.h b/Exam/IKT203Exam/Submissions/Submission-01/main.h
new file mode 100644
index 0000000..ccf6e27
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-01/main.h
@@ -0,0 +1,8 @@
+// Submission-01.h : Include file for standard system include files,
+// or project specific include files.
+
+#pragma once
+
+#include
+
+// TODO: Reference additional headers your program requires here.
diff --git a/Exam/IKT203Exam/Submissions/Submission-02/CMakeLists.txt b/Exam/IKT203Exam/Submissions/Submission-02/CMakeLists.txt
new file mode 100644
index 0000000..28e1424
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-02/CMakeLists.txt
@@ -0,0 +1,13 @@
+# CMakeList.txt : CMake project for Submission-01, include source and define
+# project specific logic here.
+#
+
+# Add source to this project's executable.
+add_executable (Submission-02 "main.cpp" "main.h")
+target_link_libraries(Submission-02 PRIVATE LibExample)
+
+if (CMAKE_VERSION VERSION_GREATER 3.20)
+ set_property(TARGET Submission-02 PROPERTY CXX_STANDARD 20)
+endif()
+
+# TODO: Add tests and install targets if needed.
diff --git a/Exam/IKT203Exam/Submissions/Submission-02/main.cpp b/Exam/IKT203Exam/Submissions/Submission-02/main.cpp
new file mode 100644
index 0000000..dcad68d
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-02/main.cpp
@@ -0,0 +1,121 @@
+// Submission-01.cpp : Defines the entry point for the application.
+//
+
+#include "main.h"
+#include
+
+
+// printNaturalNumbers
+static void printNaturalNumbers(int aN)
+{
+ if (aN <= 0) return; // Base case: if n is less than or equal to 0, do nothing
+ printNaturalNumbers(aN - 1); // Recursive call with n-1
+ std::cout << aN << " "; // Print the number after the recursive call to achieve ascending order
+}
+
+// factorial function
+static int calculateFactorial(int aN)
+{
+ if (aN <= 1) return 1; // Base case: factorial of 0 or 1 is 1
+ return aN * calculateFactorial(aN - 1); // Recursive call
+}
+
+// power function using exponentiation by squaring
+// This method is more efficient than the naive approach, reducing the time complexity from O(n) to O(log n).
+static int power(int aBase, int aExponent)
+{
+ if (aExponent == 0) return 1; // Base case: any number to the power of 0 is 1
+ if (aExponent < 0) return 1 / power(aBase, -aExponent); // Handle negative exponents
+ if (aExponent % 2 == 0) // If exponent is even
+ {
+ int halfPower = power(aBase, aExponent / 2);
+ return halfPower * halfPower; // (x^(n/2))^2
+ }
+ else // If exponent is odd
+ {
+ return aBase * power(aBase, aExponent - 1); // x * x^(n-1)
+ }
+}
+
+// Fibonacci function
+// Note: This naive recursive solution is inefficient because it recalculates the same Fibonacci numbers multiple times, leading to an exponential time complexity of O(2^n).
+// An improvement could be made by using memoization or an iterative approach to store previously calculated values, reducing the time complexity to O(n).
+static int fibonacci(int aN)
+{
+ if (aN <= 0) return 0; // Base case: fibonacci(0) = 0
+ if (aN == 1) return 1; // Base case: fibonacci(1) = 1
+ int a = fibonacci(aN - 1);
+ int b = fibonacci(aN - 2);
+ std::cout << a << " + " << b << " = " << (a + b) << std::endl; // Print the sum of the two preceding numbers
+ return a + b; // Recursive call
+}
+
+// Count occurrences of a character in a string
+// This function counts how many times a specific character appears in a given string using recursion.
+static int countOccurrences(const char* aS, char aC)
+{
+ if (*aS == '\0') return 0; // Base case: end of string
+ return (*aS == aC ? 1 : 0) + countOccurrences(aS + 1, aC); // Check current character and recurse for the rest of the string
+}
+
+// Find the largest element in an array using binary recursion
+// This function divides the array into two halves, finds the largest element in each half recursively, and then returns the larger of the two.
+static int findLargestElement(int arr[], int size)
+{
+ if (size == 1) return arr[0]; // Base case: only one element
+ int mid = size / 2;
+ int leftMax = findLargestElement(arr, mid); // Find max in left half
+ int rightMax = findLargestElement(arr + mid, size - mid); // Find max in right half
+ return (leftMax > rightMax) ? leftMax : rightMax; // Return the larger of the two
+}
+
+// Traverse and print characters in the ASCII table from aStart to aEnd using recursion
+// This function prints characters in ascending order during the building phase of the recursion and in descending order during the unwinding phase.
+static void traverseAsciiTable(char aStart, char aEnd)
+{
+ if (aStart > aEnd) return; // Base case: if start exceeds end, do nothing
+ std::cout << aStart << " "; // Print before the recursive call
+ traverseAsciiTable(aStart + 1, aEnd); // Recursive call with next character
+ std::cout << aStart << " "; // Print after the recursive call
+}
+
+int main()
+{
+ std::cout << "--- Submission 2: Fundamental Recursion ---" << std::endl;
+ std::cout << std::endl << "Part 1: Linear Recursion - Your First Steps" << std::endl;
+ printNaturalNumbers(5);
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ std::cout << std::endl << "Factorial of 5: " << calculateFactorial(5);
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ std::cout << std::endl << "Part 2: Multiple & Binary Recursion - Diving Deeper" << std::endl;
+ std::cout << std::endl << "2^10: " << power(2, 10);
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ std::cout << std::endl << "4th Fibonacci number: " << std::endl << fibonacci(4);
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ std::cout << std::endl << "Occurrences of 'l' in 'Hello, World!': " << countOccurrences("Hello, World!", 'l');
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ int* arr = new int[20];
+ // Fill array with random numbers from 0 to 999
+ for (int i = 0; i < 20; ++i) arr[i] = rand() % 999;
+ std::cout << std::endl << "Part 3: Advanced Binary Recursion" << std::endl;
+ // Print first 20 elements of the array
+ for (int i = 0; i < 20; ++i) std::cout << arr[i] << " ";
+
+ std::cout << std::endl << "Largest element in array: " << findLargestElement(arr, 20);
+ std::cout << std::endl << "------------------------------------------------" << std::endl;
+
+ std::cout << std::endl << "Traverse ASCII table from 'A' to 'Z':" << std::endl;
+ traverseAsciiTable('A', 'Z');
+
+ /*
+ Note: The output reflects the building and unwinding of the call stack.
+ */
+
+ std::cout << std::endl;
+ return 0;
+}
diff --git a/Exam/IKT203Exam/Submissions/Submission-02/main.h b/Exam/IKT203Exam/Submissions/Submission-02/main.h
new file mode 100644
index 0000000..ccf6e27
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-02/main.h
@@ -0,0 +1,8 @@
+// Submission-01.h : Include file for standard system include files,
+// or project specific include files.
+
+#pragma once
+
+#include
+
+// TODO: Reference additional headers your program requires here.
diff --git a/Exam/IKT203Exam/Submissions/Submission-03/CMakeLists.txt b/Exam/IKT203Exam/Submissions/Submission-03/CMakeLists.txt
new file mode 100644
index 0000000..e5d6092
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-03/CMakeLists.txt
@@ -0,0 +1,13 @@
+# CMakeList.txt : CMake project for Submission-01, include source and define
+# project specific logic here.
+#
+
+# Add source to this project's executable.
+add_executable (Submission-03 "main.cpp" "main.h")
+target_link_libraries(Submission-03 PRIVATE LibExample)
+
+if (CMAKE_VERSION VERSION_GREATER 3.20)
+ set_property(TARGET Submission-03 PROPERTY CXX_STANDARD 20)
+endif()
+
+# TODO: Add tests and install targets if needed.
diff --git a/Exam/IKT203Exam/Submissions/Submission-03/main.cpp b/Exam/IKT203Exam/Submissions/Submission-03/main.cpp
new file mode 100644
index 0000000..ae63d1c
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-03/main.cpp
@@ -0,0 +1,439 @@
+// Submission-01.cpp : Defines the entry point for the application.
+//
+
+#include "main.h"
+#include
+
+
+/*
+Part 1: Implementing the Core Data Structures
+These tasks are designed to get you comfortable with the Last-In, First-Out (LIFO) and First-In, First-Out (FIFO) principles. Building these yourself will give you a deep understanding of how they work under the hood!
+*/
+
+/*
+1. Implementing a Stack:
+a) Create a simple TStack class that can hold int values.
+b) Use a fixed-size array and a top-of-stack index to manage the data.
+c) Implement the core methods: Push(int item) and Pop().
+D) Add a Peek() method to view the top item without removing it.
+e) Include an IsEmpty() method to check if the stack is empty.
+*/
+
+class TStackArray {
+private:
+ int maxSize = 0;
+ int* stackArray = nullptr;
+ int top = -1; // Index of the top element
+public:
+ TStackArray(int aSize) : maxSize(aSize) {
+ stackArray = new int[maxSize];
+ }
+ ~TStackArray() {
+ delete[] stackArray;
+ }
+ void Push(int aItem) {
+ if (top < maxSize - 1) {
+ stackArray[++top] = aItem;
+ }
+ else {
+ std::cout << "Stack Overflow" << std::endl;
+ }
+ }
+ int Pop() {
+ if (!IsEmpty()) {
+ return stackArray[top--];
+ }
+ else {
+ std::cout << "Stack Underflow" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ int Peek() const {
+ if (!IsEmpty()) {
+ return stackArray[top];
+ }
+ else {
+ std::cout << "Stack is empty" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ bool IsEmpty() const {
+ return top == -1;
+ }
+};
+
+
+/*
+2. Implementing a Queue:
+a) Create a simple TQueue class that can hold int values.
+b) Use a fixed-size array and front/back indices to manage the data.
+c) Implement the core methods: Enqueue(int item) and Dequeue().
+d) Add a Peek() method to view the item at the front without removing it.
+e) Include an IsEmpty() method to check if the queue is empty.
+*/
+
+class TQueueArray {
+private:
+ int maxSize = 0;
+ int* queueArray = nullptr;
+ int front = 0; // Index of the front element
+ int back = -1; // Index of the back element
+ int itemCount = 0; // Number of items in the queue
+public:
+ TQueueArray(int aSize) : maxSize(aSize) {
+ queueArray = new int[maxSize];
+ }
+ ~TQueueArray() {
+ delete[] queueArray;
+ }
+ void Enqueue(int aItem) {
+ if (itemCount < maxSize) {
+ back = (back + 1) % maxSize; // Circular increment
+ queueArray[back] = aItem;
+ itemCount++;
+ }
+ else {
+ std::cout << "Queue Overflow" << std::endl;
+ }
+ }
+ int Dequeue() {
+ if (!IsEmpty()) {
+ int item = queueArray[front];
+ front = (front + 1) % maxSize; // Circular increment
+ itemCount--;
+ return item;
+ }
+ else {
+ std::cout << "Queue Underflow" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ int Peek() const {
+ if (!IsEmpty()) {
+ return queueArray[front];
+ }
+ else {
+ std::cout << "Queue is empty" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ bool IsEmpty() const {
+ return itemCount == 0;
+ }
+};
+
+class TNodeInteger {
+public:
+ int data;
+ TNodeInteger* next;
+ TNodeInteger(int aData) : data(aData), next(nullptr) {}
+};
+
+// Stack implemented using a linked list with dummy head node
+class TStackLinkedList {
+private:
+ TNodeInteger* top = nullptr;
+public:
+ TStackLinkedList() {
+ top = new TNodeInteger(0); // Dummy head node
+ }
+ ~TStackLinkedList() {
+ while (!IsEmpty()) {
+ Pop();
+ }
+ delete top; // Delete dummy head node
+ }
+ void Push(int aItem) {
+ TNodeInteger* newNode = new TNodeInteger(aItem);
+ newNode->next = top->next;
+ top->next = newNode;
+ }
+ int Pop() {
+ if (!IsEmpty()) {
+ TNodeInteger* temp = top->next;
+ int item = temp->data;
+ top->next = temp->next;
+ delete temp; // Free memory
+ return item;
+ }
+ else {
+ std::cout << "Stack Underflow" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ int Peek() const {
+ if (!IsEmpty()) {
+ return top->next->data;
+ }
+ else {
+ std::cout << "Stack is empty" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ bool IsEmpty() const {
+ return top->next == nullptr;
+ }
+};
+
+// Queue implemented using a linked list with dummy head node
+class TQueueLinkedList {
+private:
+ TNodeInteger* front = nullptr;
+ TNodeInteger* back = nullptr;
+public:
+ TQueueLinkedList() {
+ front = new TNodeInteger(0); // Dummy head node
+ back = front; // Initially, front and back point to the dummy node
+ }
+ ~TQueueLinkedList() {
+ while (!IsEmpty()) {
+ Dequeue();
+ }
+ delete front; // Delete dummy head node
+ }
+ void Enqueue(int aItem) {
+ TNodeInteger* newNode = new TNodeInteger(aItem);
+ back->next = newNode;
+ back = newNode;
+ }
+ int Dequeue() {
+ if (!IsEmpty()) {
+ TNodeInteger* temp = front->next;
+ int item = temp->data;
+ front->next = temp->next;
+ if (back == temp) { // If the dequeued node was the last node
+ back = front; // Reset back to the dummy head
+ }
+ delete temp; // Free memory
+ return item;
+ }
+ else {
+ std::cout << "Queue Underflow" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ int Peek() const {
+ if (!IsEmpty()) {
+ return front->next->data;
+ }
+ else {
+ std::cout << "Queue is empty" << std::endl;
+ return -1; // Indicate error
+ }
+ }
+ bool IsEmpty() const {
+ return front->next == nullptr;
+ }
+};
+
+
+
+/*
+Part 2: Practical Applications
+Now that you have your own data structures, it's time to put them to work! These are classic problems that perfectly demonstrate the LIFO and FIFO principles.
+*/
+
+/*
+3. String Reversal with a Stack:
+a) Write a function that takes a string as input and uses your TStack to return the reversed string.
+b) In a short comment, explain why the stack is the perfect tool for this type of task.
+*/
+
+static std::string ReverseString(const char* aStr) {
+ TStackArray stack(strlen(aStr));
+ for (int i = 0; aStr[i] != '\0'; i++) {
+ stack.Push(aStr[i]);
+ }
+ std::string reversed;
+ while (!stack.IsEmpty()) {
+ reversed += static_cast(stack.Pop()); // Cast int back to char
+ }
+ return reversed;
+ /*
+ * Note: The stack is the perfect tool for string reversal because it allows us to push each character of the string onto the stack and then pop them off in reverse order.
+ * And stack is using the rule of LIFO (Last In First Out), so the last character pushed onto the stack will be the first one to be popped off, effectively reversing the order of characters.
+ */
+}
+
+/*
+4. Recursive Functions with a Stack:
+a) Remember the factorial function you implemented with recursion in Submission 2? Your computer used a hidden "call stack" to make that happen. Now, your task is to re-implement that function without recursion, using your own `TStack` to manage the process.
+b) This is a fantastic exercise that will give you a "eureka" moment about how recursion truly works!
+*/
+
+static int Factorial(int n) {
+ if (n < 0) return -1; // Factorial is not defined for negative numbers
+ if (n == 0 || n == 1) return 1; // Base case
+ TStackArray stack(n);
+ for (int i = 2; i <= n; i++) {
+ stack.Push(i);
+ }
+ int result = 1;
+ while (!stack.IsEmpty()) {
+ result *= stack.Pop();
+ }
+ return result;
+}
+
+/*
+5. Wait Line Simulation with a Queue:
+a) Simulate a simple waiting line, such as a ticket counter.
+b) Use your TQueue to manage a list of people (represented by integer IDs).
+c) People should Enqueue when they arrive and Dequeue when they are served, clearly demonstrating the FIFO principle.
+*/
+
+static void SimulateWaitLine() {
+ TQueueArray queue(5); // Queue with a maximum size of 5
+ // Simulate people arriving
+ for (int i = 1; i <= 5; i++) {
+ std::cout << "Person " << i << " arrives." << std::endl;
+ queue.Enqueue(i);
+ }
+ // Simulate serving people
+ while (!queue.IsEmpty()) {
+ int person = queue.Dequeue();
+ std::cout << "Person " << person << " is served." << std::endl;
+ }
+}
+
+/*
+Part 3: Advanced Traversal - Stacks vs. Queues
+This is the main event! You will solve the same problem using two different approaches, highlighting the different strengths of stacks and queues.
+Your recursive functions from Submission 2 actually use an implicit stack, so this task will give you a deeper look into how it all works.
+*/
+
+/*
+6. Setup: The 100x100 Grid:
+a) Create a 100x100 two-dimensional integer array.
+b) Populate the array with random integer values between 0 and 9.
+c) Choose a random starting cell (row, col).
+d) Create a second 100x100 boolean array to keep track of visited cells.
+*/
+
+
+static const int GRID_SIZE = 7;
+static int grid[GRID_SIZE][GRID_SIZE];
+static bool visited[GRID_SIZE][GRID_SIZE] = { false };
+#include
+#include
+static void InitializeGrid() {
+ std::srand(static_cast(std::time(0))); // Seed for randomness
+ for (int i = 0; i < GRID_SIZE; i++) {
+ for (int j = 0; j < GRID_SIZE; j++) {
+ grid[i][j] = std::rand() % 9; // Random values between 0 and 9
+ visited[i][j] = false; // Initialize visited array
+ }
+ }
+}
+
+/*
+7. Depth-First Search (DFS) with a Stack:
+a) Write a function that uses your TStack to perform a DFS on the grid, starting from your random cell.
+b) The goal is to find the first occurrence of the number '0'.
+c) In a short comment, explain how the LIFO behavior of the stack guides the search to explore as deeply as possible along one path before backtracking.
+*/
+
+
+// Helper function to check if a cell is within bounds and not visited
+static bool IsValid(int aRow, int aCol) {
+ return aRow >= 0 && aRow < GRID_SIZE && aCol >= 0 && aCol < GRID_SIZE && !visited[aRow][aCol];
+}
+
+// The stack's LIFO behavior allows the DFS to explore one path fully before backtracking, ensuring that all possible routes are checked in depth-first order.
+static bool DFS(int aStartRow, int aStartCol) {
+ TStackArray stack(GRID_SIZE * GRID_SIZE);
+ int cellPos = aStartRow * GRID_SIZE + aStartCol; // Encode 2D position as 1D
+ stack.Push(cellPos);
+ while (!stack.IsEmpty()) {
+ cellPos = stack.Pop();
+ int row = cellPos / GRID_SIZE;
+ int col = cellPos % GRID_SIZE;
+ if (grid[row][col] == 0) {
+ std::cout << "Found 0 at (" << row << ", " << col << ")" << std::endl;
+ return true;
+ }
+ std::cout << "Visiting (" << row << ", " << col << ") with value " << grid[row][col] << std::endl;
+ visited[row][col] = true;
+ int neighbors[4][2] = { {row - 1, col}, {row, col + 1}, {row + 1, col}, {row, col - 1} };
+ for (int i = 0; i < 4; i++) {
+ int newRow = neighbors[i][0];
+ int newCol = neighbors[i][1];
+ if (IsValid(newRow, newCol)) {
+ cellPos = newRow * GRID_SIZE + newCol;
+ stack.Push(cellPos);
+ }
+ }
+ }
+ std::cout << "0 not found in DFS" << std::endl;
+ return false;
+}
+
+// The queue's FIFO behavior ensures that the BFS explores all neighbors at the present depth prior to moving on to nodes at the next depth level, effectively searching layer by layer.
+static bool BFS(int aStartRow, int aStartCol) {
+ int row = aStartRow, col = aStartCol;
+ int pos = row * GRID_SIZE + col; // Encode 2D position as 1D
+ TQueueArray queue(GRID_SIZE * GRID_SIZE);
+ queue.Enqueue(pos);
+ while (!queue.IsEmpty()) {
+ pos = queue.Dequeue();
+ row = pos / GRID_SIZE;
+ col = pos % GRID_SIZE;
+ if (grid[row][col] == 0) {
+ std::cout << "Found 0 at (" << row << ", " << col << ")" << std::endl;
+ return true;
+ }
+ std::cout << "Visiting (" << row << ", " << col << ") with value " << grid[row][col] << std::endl;
+ visited[row][col] = true;
+ int neighbors[4][2] = { {row - 1, col}, {row, col + 1},{row + 1, col},{row, col - 1} };
+ for (int i = 0; i < 4; i++) {
+ row = neighbors[i][0];
+ col = neighbors[i][1];
+ if (IsValid(row, col)) {
+ pos = row * GRID_SIZE + col;
+ queue.Enqueue(pos);
+ }
+ }
+ }
+ std::cout << "0 not found in BFS" << std::endl;
+ return false;
+}
+
+
+int main()
+{
+ std::cout << "--- Submission 3: Stacks & Queues ---" << std::endl;
+ std::string original = "Hello, World!";
+ std::string reversed = ReverseString(original.c_str());
+ std::cout << "Original String: " << original << std::endl;
+ std::cout << "Reversed String: " << reversed << std::endl;
+ // The stack is the perfect tool for string reversal because it operates on a Last-In, First-Out (LIFO) principle.
+ // This means that the last character pushed onto the stack will be the first one to be popped off, effectively reversing the order of characters.
+ std::cout << "----------------------------------------------------" << std::endl << std::endl;
+
+ std::cout << "Calculating Factorial of 5 using Stack:" << std::endl;
+ std::cout << "5! = " << Factorial(5) << std::endl;
+ std::cout << "----------------------------------------------------" << std::endl << std::endl;
+
+ std::cout << "Simulating Wait Line using Queue:" << std::endl;
+ SimulateWaitLine();
+ std::cout << "----------------------------------------------------" << std::endl << std::endl;
+
+ std::cout << "Initializing 100x100 Grid and Performing DFS to find '0':" << std::endl;
+ InitializeGrid();
+ int startRow = 3; //std::rand() % GRID_SIZE;
+ int startCol = 2; //std::rand() % GRID_SIZE;
+ std::cout << "Starting DFS from (" << startRow << ", " << startCol << ")" << std::endl;
+ DFS(startRow, startCol);
+ std::cout << std::endl << "Re-initializing visited array for BFS:" << std::endl;
+ for (int i = 0; i < GRID_SIZE; i++) {
+ for (int j = 0; j < GRID_SIZE; j++) {
+ visited[i][j] = false; // Reset visited array
+ }
+ }
+ std::cout << "Stating BFS from (" << startRow << ", " << startCol << ")" << std::endl;
+ BFS(startRow, startCol); // This should find a different path to '0'
+ std::cout << "----------------------------------------------------" << std::endl << std::endl;
+
+
+ return 0;
+}
diff --git a/Exam/IKT203Exam/Submissions/Submission-03/main.h b/Exam/IKT203Exam/Submissions/Submission-03/main.h
new file mode 100644
index 0000000..ccf6e27
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-03/main.h
@@ -0,0 +1,8 @@
+// Submission-01.h : Include file for standard system include files,
+// or project specific include files.
+
+#pragma once
+
+#include
+
+// TODO: Reference additional headers your program requires here.
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.cpp b/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.cpp
new file mode 100644
index 0000000..94bcf1e
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.cpp
@@ -0,0 +1,108 @@
+#include "BankAccount.h"
+#include
+#include
+#include
+#include // For rand()
+#include // For better random number generation
+#include
+#include // For memset
+#include // For floor
+#include // For time manipulation
+#include // For locale settings
+#include // For codecvt_utf8
+#include // For std::invalid_argument
+#include
+
+
+TBankAccount::TBankAccount(EBankAccountType accType, std::string firstName, std::string lastName)
+ : accountType(accType), ownerFirstName(firstName), ownerLastName(lastName)
+{
+ // Random genration of account number: XXXX.XX.XXXXX
+ accountNumber = toString(rand() % 9000 + 1000) + "." + toString(rand() % 90 + 10) + "." + toString(rand() % 90000 + 10000);
+
+ balance = 0.0f;
+
+ //Random generation of creation timestamp, date is any date and time in 2024
+ int month = rand() % 12 + 1;
+ int day = rand() % 28 + 1; // To avoid complexity of different month lengths
+ int hour = rand() % 24;
+ int minute = rand() % 60;
+
+ // Calculate creation timestamp in seconds from 2024-01-01 00:00:00
+std:tm tm = {};
+ tm.tm_year = 2024 - 1900; // Year since 1900
+ tm.tm_mon = rand() % 12; // Month [0-11]
+ tm.tm_mday = rand() % 28 + 1; // Day of the month [1-28] to avoid month length issues
+ tm.tm_hour = rand() % 24; // Hour [0-23]
+ tm.tm_min = rand() % 60; // Minute [0-59]
+ tm.tm_sec = 0; // Second [0-59]
+ creationTimestamp = _mkgmtime(&tm); // Use _mkgmtime for UTC
+
+ if (accType == Checking || accType == Saving || accType == Pension)
+ balance = static_cast(rand() % 1001); // 0 to 1000
+ else if (accType == Loan)
+ balance = static_cast(-(rand() % 25001 + 25000)); // -50000 to -25000
+ else if (accType == Credit)
+ balance = static_cast(-(rand() % 1001)); // -1000 to 0
+}
+
+TBankAccount::~TBankAccount()
+{
+ // Destructor logic if needed
+}
+
+std::string TBankAccount::getAccountNumber() const {
+ return accountNumber;
+}
+
+EBankAccountType TBankAccount::getAccountType() const {
+ return accountType;
+}
+
+time_t TBankAccount::getCreationTimestamp() const {
+ return creationTimestamp;
+}
+double TBankAccount::getBalance() const {
+ return balance;
+}
+void TBankAccount::deposit(double aAmount) {
+ if (aAmount > 0) balance += aAmount;
+}
+
+void TBankAccount::withdraw(double aAmount) {
+ if (aAmount > 0 && aAmount <= balance) balance -= aAmount;
+}
+
+std::string TBankAccount::getAccountTypeString() const
+{
+ switch (accountType)
+ {
+ case Checking: return "Checking";
+ case Saving: return "Saving";
+ case Credit: return "Credit";
+ case Pension: return "Pension";
+ case Loan: return "Loan";
+ default: return "Unknown";
+ }
+}
+
+//
+std::string TBankAccount::getCreationTimeString() const
+{
+ char buffer[26];
+ ctime_s(buffer, sizeof(buffer), &creationTimestamp);
+ std::string timeString(buffer);
+ if (!timeString.empty() && timeString.back() == '\n') {
+ timeString.pop_back(); // Remove the trailing newline character
+ }
+ return timeString;
+}
+
+void TBankAccount::printAccountInfo() const
+{
+ std::cout << "Account Number: " << accountNumber << ", Type: " << getAccountTypeString()
+ << ", Owner: " << ownerFirstName << " " << ownerLastName
+ << ", Balance: " << balance
+ << ", Created: " << getCreationTimeString()
+ << std::endl;
+}
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.h b/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.h
new file mode 100644
index 0000000..077b767
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/BankAccount.h
@@ -0,0 +1,52 @@
+#pragma once
+#ifndef BANKACCOUNT_H
+#define BANKACCOUNT_H
+
+#include // For std::string
+#include // For time_t
+#include // For rand()
+#include // For std::setfill and std::setw
+#include // For std::ostringstream
+#include // For std::cout
+
+
+// Helper function to convert value to string
+template
+std::string toString(T value)
+{
+ std::ostringstream oss;
+ oss << value;
+ return oss.str();
+}
+
+
+enum EBankAccountType { Checking, Saving, Credit, Pension, Loan };
+
+class TBankAccount {
+
+private:
+ std::string accountNumber;
+ EBankAccountType accountType;
+ time_t creationTimestamp;
+ double balance;
+
+public:
+ std::string ownerFirstName;
+ std::string ownerLastName;
+
+ //TBankAccount() {} // Don't use default constructor
+ TBankAccount(EBankAccountType, std::string, std::string);
+ ~TBankAccount();
+
+ std::string getAccountNumber() const;
+ std::string getCreationTimeString() const;
+ time_t getCreationTimestamp() const;
+ double getBalance() const;
+ void deposit(double);
+ void withdraw(double);
+ EBankAccountType getAccountType() const;
+ std::string getAccountTypeString() const;
+ void printAccountInfo() const;
+};
+
+#endif // BANKACCOUNT_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.cpp b/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.cpp
new file mode 100644
index 0000000..fb049d4
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.cpp
@@ -0,0 +1,130 @@
+#include "BankAccountList.h"
+
+TLinkedList::TLinkedList(bool aOwnsData) : head(nullptr), ownsData(aOwnsData), size(0) {
+ head = new TLinkedListNode(nullptr); // Dummy head node
+}
+
+TLinkedList::~TLinkedList()
+{
+ while (head->next != nullptr)
+ {
+ TLinkedListNode* temp = head->next;
+ head->next = temp->next;
+ if (ownsData) delete temp->data; // Delete the TBankAccount object
+ delete temp; // Delete the node
+ }
+ delete head;
+}
+
+int TLinkedList::getSize() const { return size; }
+
+void TLinkedList::Add(TBankAccount* aData)
+{
+ TLinkedListNode* newNode = new TLinkedListNode(aData);
+ newNode->next = head->next;
+ head->next = newNode;
+ size++;
+}
+
+TBankAccount* TLinkedList::Find(FCompareAccount aCompareFunc, void* aSearchKey)
+{
+ TLinkedListNode* current = head->next;
+ while (current != nullptr)
+ {
+ if (aCompareFunc(current->data, aSearchKey))
+ {
+ return current->data; // Found
+ }
+ current = current->next;
+ }
+ return nullptr; // Not found
+}
+
+TLinkedList* TLinkedList::Every(FCompareAccount aCompareFunc, void* aSearchKey)
+{
+ TLinkedList* resultList = new TLinkedList(false); // New list does not own data
+ TLinkedListNode* current = head->next;
+ while (current != nullptr)
+ {
+ if (aCompareFunc(current->data, aSearchKey))
+ {
+ resultList->Add(current->data); // Add to result list
+ }
+ current = current->next;
+ }
+ return resultList; // Return the new list
+}
+
+// Loop through all accounts, if aEveryFunc returns false for any, return that account
+TBankAccount* TLinkedList::Every(FEveryAccount aEveryFunc) {
+ TLinkedListNode* current = head->next;
+ int index = 0;
+ while (current != nullptr)
+ {
+ if (!aEveryFunc(current->data, index++))
+ {
+ return current->data; // Return the first account that fails the test
+ }
+ current = current->next;
+ }
+ return nullptr; // All accounts passed the test
+}
+
+TBankAccount** TLinkedList::ToArray()
+{
+ if (size == 0) return nullptr;
+ TBankAccount** array = new TBankAccount * [size];
+ TLinkedListNode* current = head->next;
+ int index = 0;
+ while (current != nullptr && index < size) // Ensure index < size
+ {
+ array[index++] = current->data;
+ current = current->next;
+ }
+ return array;
+}
+
+void TLinkedList::forEach(FForEachAccount aFunc)
+{
+ TLinkedListNode* current = head->next;
+ int index = 0;
+ while (current != nullptr)
+ {
+ aFunc(current->data, index++);
+ current = current->next;
+ }
+}
+
+TLinkedListNode* TLinkedList::getHead() const { return head; }
+
+void TLinkedList::Append(TBankAccount* account)
+{
+ TLinkedListNode* newNode = new TLinkedListNode(account);
+ TLinkedListNode* current = head;
+ while (current->next != nullptr)
+ {
+ current = current->next;
+ }
+ current->next = newNode;
+ size++;
+}
+
+void TLinkedList::Remove(TBankAccount* account)
+{
+ TLinkedListNode* current = head;
+ while (current->next != nullptr)
+ {
+ if (current->next->data == account)
+ {
+ TLinkedListNode* temp = current->next;
+ current->next = temp->next;
+ if (ownsData) delete temp->data; // Delete the TBankAccount object
+ delete temp; // Delete the node
+ size--;
+ return; // Exit after removing
+ }
+ current = current->next;
+ }
+}
+
+
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.h b/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.h
new file mode 100644
index 0000000..2b6d7df
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/BankAccountList.h
@@ -0,0 +1,51 @@
+#pragma once
+#ifndef BANKACCOUNTLIST_H
+#define BANKACCOUNTLIST_H
+#include "BankAccount.h"
+#include
+#include
+
+typedef bool (*FCompareAccount)(TBankAccount* account, void* searchKey);
+typedef void (*FForEachAccount)(TBankAccount* account, int index);
+typedef bool (*FEveryAccount)(TBankAccount*, int);
+
+// Node class for linked list
+class TLinkedListNode
+{
+public:
+ TBankAccount* data;
+ TLinkedListNode* next;
+ TLinkedListNode(TBankAccount* aData) : data(aData), next(nullptr) {}
+ ~TLinkedListNode()
+ {
+ // Destructor logic if needed
+ }
+};
+
+// Use dummy head node for simplicity
+class TLinkedList
+{
+private:
+ TLinkedListNode* head;
+ bool ownsData;
+ int size;
+public:
+ TLinkedList(bool);
+ ~TLinkedList();
+ int getSize() const;
+ TLinkedListNode* getHead() const;
+
+ void Add(TBankAccount*);
+
+ TBankAccount* Find(FCompareAccount, void*);
+
+ TLinkedList* Every(FCompareAccount, void*);
+ TBankAccount* Every(FEveryAccount aEveryFunc);
+ TBankAccount** ToArray();
+ void forEach(FForEachAccount);
+
+ void Append(TBankAccount* account);
+ void Remove(TBankAccount* account);
+};
+
+#endif// BANKACCOUNTLIST_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/CMakeLists.txt b/Exam/IKT203Exam/Submissions/Submission-04/CMakeLists.txt
new file mode 100644
index 0000000..01fc28e
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/CMakeLists.txt
@@ -0,0 +1,25 @@
+# CMakeList.txt : CMake project for Submission-01, include source and define
+# project specific logic here.
+#
+
+# Add source to this project's executable.
+add_executable (Submission-04 "main.cpp" "main.h" "BankAccount.h" "ReadNames.cpp" "ReadNames.h" "BankAccount.cpp" "BankAccount.h" "BankAccountList.cpp" "BankAccountList.h")
+target_link_libraries(Submission-04 PRIVATE LibExample)
+
+# Add source files to a Submission04Lib library
+add_library(Submission04Lib
+ BankAccount.cpp
+ BankAccount.h
+ ReadNames.cpp
+ ReadNames.h
+ BankAccountList.cpp
+ BankAccountList.h
+)
+
+target_include_directories(Submission04Lib PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
+
+if (CMAKE_VERSION VERSION_GREATER 3.20)
+ set_property(TARGET Submission-03 PROPERTY CXX_STANDARD 20)
+endif()
+
+# TODO: Add tests and install targets if needed.
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.cpp b/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.cpp
new file mode 100644
index 0000000..0b6d01f
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.cpp
@@ -0,0 +1,31 @@
+#include
+#include
+#include
+#include
+#include "ReadNames.h"
+
+void readNamesFromFile(const std::string& aFilename, FNameRead aOnNameRead)
+{
+ if (aFilename.empty()) return;
+ std::ifstream file(aFilename);
+ if (!file.is_open())
+ {
+ std::cerr << "Error opening file: " << aFilename << std::endl;
+ return;
+ }
+ std::string line;
+ while (std::getline(file, line))
+ {
+ std::istringstream iss(line);
+ std::string firstName, lastName;
+ if (iss >> firstName >> lastName)
+ {
+ if (aOnNameRead) // If the callback is set, call it
+ {
+ //If the function returns false, stop reading further
+ if (!aOnNameRead(firstName, lastName)) break;
+ }
+ }
+ }
+ file.close();
+}
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.h b/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.h
new file mode 100644
index 0000000..b1428b5
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/ReadNames.h
@@ -0,0 +1,30 @@
+#pragma once
+#ifndef READNAMES_H
+#define SHARED_LIB_H
+#include
+#include
+
+///
+/// Use this delegate type to define a callback function for processing names read from a file.
+///
+/// FNameRead
+/// A function pointer type for a callback that processes names read from a file.
+/// The first name read from the file.
+/// The last name read from the file.
+/// Returns true to continue reading names, or false to stop.
+typedef bool (*FNameRead)(const std::string& firstName, const std::string& lastName);
+
+///
+/// Use this function to read names from a specified file and process them using a callback function.
+///
+/// readNamesFromFile
+/// Reads names from a specified file and invokes a callback for each name read.
+/// The path to the file containing names.
+/// A callback function that is called for each name read. It takes two parameters: firstName and lastName. If the callback returns false, the reading process stops.
+/// The first name read from the file.
+/// The last name read from the file.
+/// None.
+void readNamesFromFile(const std::string& aFilename, FNameRead aOnNameRead);
+
+
+#endif // READNAMES_H
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/main.cpp b/Exam/IKT203Exam/Submissions/Submission-04/main.cpp
new file mode 100644
index 0000000..71f0f90
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/main.cpp
@@ -0,0 +1,180 @@
+// Submission-01.cpp : Defines the entry point for the application.
+//
+
+#include "main.h"
+#include "ReadNames.h" // For reading names from file
+#include "BankAccount.h" // For TBankAccount and EBankAccountType
+#include "BankAccountList.h" // For TLinkedList
+#include // For std::getline and std::string
+#include // For std::cout
+#include // For std::istringstream
+
+
+
+// For statistics
+typedef struct _TSummary {
+ long comparisonCount = 0;
+ double timeTaken = 0.0;
+}TSummary;
+static TSummary statistics;
+
+
+
+static EBankAccountType getRandomAccountType()
+{
+ return static_cast(rand() % 5); // Randomly returns one of the 5 account types
+}
+
+TLinkedList* bankAccounts = new TLinkedList(true); // List owns the TBankAccount objects
+TBankAccount** bankAccountArray = nullptr;
+
+
+static bool OnNameRead(const std::string& firstName, const std::string& lastName)
+{
+ //For each name read, create from 5 to 10 random bank accounts
+ int accountCount = rand() % 6 + 5; // Random number between 5 and 10
+ for (int i = 0; i < accountCount; i++)
+ {
+ EBankAccountType accType = getRandomAccountType();
+ TBankAccount* newAccount = new TBankAccount(accType, firstName, lastName);
+ bankAccounts->Add(newAccount);
+ }
+ return true; //bankAccounts->getSize() < 100; // For demo purposes
+}
+
+static void resetStatistics()
+{
+ statistics.comparisonCount = 0;
+ statistics.timeTaken = (static_cast(clock())) / CLOCKS_PER_SEC;
+}
+
+static void printStastics() {
+ statistics.timeTaken = (static_cast(clock())) / CLOCKS_PER_SEC - statistics.timeTaken;
+ std::cout << "Comparisons: " << statistics.comparisonCount << ", Time taken: " << statistics.timeTaken << " seconds." << std::endl;
+}
+
+/*
+Part 3: Standalone Search Functions (The External Analyst)
+To simulate working with data from different perspectives, you will also implement search functions that are not part of the list class. These functions will operate on a simple array of pointers.
+*/
+
+static TBankAccount* FindAccountByNumber(TBankAccount** accountArray, int arraySize, const std::string& accountNumber) {
+ if (accountArray == nullptr || arraySize <= 0) return nullptr;
+ for (int i = 0; i < arraySize; i++) {
+ statistics.comparisonCount++;
+ if (accountArray[i]->getAccountNumber() == accountNumber) {
+ return accountArray[i]; // Found
+ }
+ }
+ return nullptr; // Not found
+}
+
+static void PrintEveryAccountInDateRange(TBankAccount** accountArray, int arraySize, time_t from, time_t to) {
+ if (accountArray == nullptr || arraySize <= 0) return;
+ std::cout << "------------------------------" << std::endl;
+ resetStatistics();
+ int foundCount = 0;
+ for (int i = 0; i < arraySize; i++) {
+ statistics.comparisonCount++;
+ time_t ts = accountArray[i]->getCreationTimestamp();
+ if (ts >= from && ts < to) {
+ std::cout << i + 1 << ". ";
+ accountArray[i]->printAccountInfo();
+ foundCount++;
+ }
+ }
+ printStastics();
+ std::cout << "Total accounts found in date range: " << foundCount << std::endl;
+}
+
+
+int main()
+{
+ std::cout << "--- Submission 4: Sosrt & Search ---" << std::endl;
+
+ // Test TBankAccount
+ //Gen random account type
+ //Change this name for you own names file
+ std::string namesFile = "F:\\IKT203\\VisualStudio\\DATA\\Random_Name.txt";
+ std::cout << "Reading names from file: " << namesFile << std::endl;
+ readNamesFromFile(namesFile, OnNameRead);
+ std::cout << "Total Bank Accounts Created: " << bankAccounts->getSize() << std::endl;
+ std::cout << "Converting linked list to array..." << std::endl;
+ bankAccountArray = bankAccounts->ToArray();
+ std::cout << "Array created with " << bankAccounts->getSize() << " accounts." << std::endl;
+
+
+ resetStatistics();
+ int getRandomIndex = rand() % bankAccounts->getSize();
+ TBankAccount* foundAccount = FindAccountByNumber(bankAccountArray, bankAccounts->getSize(), bankAccountArray[getRandomIndex]->getAccountNumber());
+ if (foundAccount)
+ {
+ std::cout << "Found Account: " << std::endl;
+ foundAccount->printAccountInfo();
+ }
+ else
+ {
+ std::cout << "Account not found." << std::endl;
+ }
+ printStastics();
+
+ resetStatistics();
+ foundAccount = FindAccountByNumber(bankAccountArray, bankAccounts->getSize(), "1234.56.78901");
+ if (foundAccount)
+ {
+ std::cout << "Found Account: " << std::endl;
+ foundAccount->printAccountInfo();
+ }
+ else
+ {
+ std::cout << "Account not found." << std::endl;
+ }
+ printStastics();
+
+ // Find All (Integrated): Use your Every() method to find all accounts created in June 2024 and print their details.
+ resetStatistics();
+ struct June2024Key {
+ time_t start;
+ time_t end;
+ };
+ June2024Key juneKey{};
+ std::tm fromToTm = {};
+ fromToTm.tm_year = 2024 - 1900; // Year since 1900
+ fromToTm.tm_mon = 5; // June (0-based)
+ fromToTm.tm_mday = 1; // 1st
+ fromToTm.tm_hour = 0;
+ fromToTm.tm_min = 0;
+ fromToTm.tm_sec = 0;
+ juneKey.start = _mkgmtime(&fromToTm); // Use _mkgmtime for UTC
+ fromToTm.tm_mday = 30; // 30th
+ fromToTm.tm_hour = 23;
+ fromToTm.tm_min = 59;
+ fromToTm.tm_sec = 59;
+ juneKey.end = _mkgmtime(&fromToTm); // Use _mkgmtime for UTC
+
+ TLinkedList* juneAccounts = bankAccounts->Every(
+ [](TBankAccount* account, void* searchKey) -> bool {
+ June2024Key* key = static_cast(searchKey);
+ time_t ts = account->getCreationTimestamp();
+ return ts >= key->start && ts < key->end;
+ }, &juneKey);
+
+ std::cout << "Accounts created in June 2024: " << juneAccounts->getSize() << std::endl;
+ printStastics();
+
+ juneAccounts->forEach(
+ [](TBankAccount* aAccount, int aIndex) {
+ std::cout << aIndex + 1 << ". ";
+ aAccount->printAccountInfo();
+ });
+
+ PrintEveryAccountInDateRange(bankAccountArray, bankAccounts->getSize(), juneKey.start, juneKey.end);
+
+
+ // Cleanup
+ // First delete the array, then the linked list
+ delete[] bankAccountArray;
+ delete bankAccounts;
+
+ return 0;
+}
diff --git a/Exam/IKT203Exam/Submissions/Submission-04/main.h b/Exam/IKT203Exam/Submissions/Submission-04/main.h
new file mode 100644
index 0000000..ccf6e27
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-04/main.h
@@ -0,0 +1,8 @@
+// Submission-01.h : Include file for standard system include files,
+// or project specific include files.
+
+#pragma once
+
+#include
+
+// TODO: Reference additional headers your program requires here.
diff --git a/Exam/IKT203Exam/Submissions/Submission-05/CMakeLists.txt b/Exam/IKT203Exam/Submissions/Submission-05/CMakeLists.txt
new file mode 100644
index 0000000..ba0a700
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-05/CMakeLists.txt
@@ -0,0 +1,13 @@
+# CMakeList.txt : CMake project for Submission-01, include source and define
+# project specific logic here.
+#
+
+# Add source to this project's executable.
+add_executable (Submission-05 "main.cpp" "main.h")
+target_link_libraries(Submission-05 PRIVATE Submission04Lib LibExample)
+
+if (CMAKE_VERSION VERSION_GREATER 3.20)
+ set_property(TARGET Submission-05 PROPERTY CXX_STANDARD 20)
+endif()
+
+# TODO: Add tests and install targets if needed.
diff --git a/Exam/IKT203Exam/Submissions/Submission-05/main.cpp b/Exam/IKT203Exam/Submissions/Submission-05/main.cpp
new file mode 100644
index 0000000..56cd8c2
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-05/main.cpp
@@ -0,0 +1,828 @@
+// Submission-01.cpp : Defines the entry point for the application.
+//
+
+#include "ReadNames.h" // For reading names from file
+#include "BankAccount.h" // For TBankAccount and EBankAccountType
+#include "BankAccountList.h" // For TLinkedList
+#include // For std::getline and std::string
+#include // For std::cout
+#include // For std::istringstream
+
+
+
+// For statistics
+typedef struct _TSummary {
+ long long comparisonCount = 0;
+ long long swaps = 0;
+ double timeTaken = 0.0;
+}TSummary;
+static TSummary statistics;
+
+
+static void resetStatistics()
+{
+ statistics.comparisonCount = 0;
+ statistics.swaps = 0;
+ statistics.timeTaken = (static_cast(clock())) / CLOCKS_PER_SEC;
+}
+
+static void printStastics() {
+ statistics.timeTaken = (static_cast(clock())) / CLOCKS_PER_SEC - statistics.timeTaken;
+ std::cout << "Comparisons: " << statistics.comparisonCount << ", Swaps: " << statistics.swaps << ", Time taken : " << statistics.timeTaken << " seconds." << std::endl;
+}
+
+
+static EBankAccountType getRandomAccountType()
+{
+ return static_cast(rand() % 5); // Randomly returns one of the 5 account types
+}
+
+TLinkedList* bankAccounts = new TLinkedList(true); // List owns the TBankAccount objects
+TBankAccount** bankAccountArray = nullptr;
+
+
+static bool OnNameRead(const std::string& firstName, const std::string& lastName)
+{
+ //For each name read, create from 5 to 10 random bank accounts
+ int accountCount = rand() % 6 + 5; // Random number between 5 and 10
+ for (int i = 0; i < accountCount; i++)
+ {
+ EBankAccountType accType = getRandomAccountType();
+ TBankAccount* newAccount = new TBankAccount(accType, firstName, lastName);
+ bankAccounts->Add(newAccount);
+ }
+ return bankAccounts->getSize() < 2500; // For demo purposes
+}
+
+/*
+Part 1: The Sorting Toolkit
+Before we can sort, we need the right tools. In this part, you'll set up a flexible, powerful sorting "engine" that can handle any sorting criteria we give it.
+
+1. The FCompareAccounts Callback:
+ a) Create a typedef for a function pointer named FCompareAccounts.
+ b) The signature must be: int (*FCompareAccounts)(TBankAccount* a, TBankAccount* b);.
+ c) This function should return a negative value if a comes before b, zero if they are equal, and a positive value if a comes after b.
+2. The OperationSummary Struct:
+ a) Create a struct named OperationSummary to track performance metrics: long long comparisons, long long swaps, and double timeSpentMs.
+3. The TSort Class:
+ a) Create a class called TSort. This will be your dedicated sorting engine.
+ b) The constructor should take pointers to the original data sources (the list and the array).
+ c) The sorting methods should create and return a new, sorted array or list, not modify the original.
+*/
+
+/*
+Part 2: The Simple Sorts (O(n²)) - Foundational, but Slow
+These algorithms are your first step. They are conceptually simpler but do not perform well on large datasets. Implementing them is essential for understanding the fundamentals.
+
+4. Selection Sort:
+ a) The Challenge: You must implement this algorithm twice in your TSort class:
+ 1. A version that sorts the pointer array.
+ 2. A version that sorts the linked list.
+ b) Pay close attention to the pointer manipulation required for the linked list versionâit's a fantastic challenge!
+5. Bubble Sort:
+ a) Implement a method in TSort that performs a Bubble Sort on the pointer array.
+
+
+Part 3: The Advanced Sorts (O(n log n)) - Divide and Conquer
+Now for the heavy hitters. These recursive, "Divide and Conquer" algorithms are far more efficient and are staples of modern software engineering.
+
+6. Quick Sort (on the Array):
+ a) Implement Quick Sort to sort the pointer array.
+ b) Your implementation must use the public/private recursion pattern. A public QuickSort() method calls a private QuickSortRecursive(...).
+ c) The heart of this algorithm is the Partition() helper function. Getting this right is the key to success!
+
+7. Merge Sort (on the Linked List):
+ a) Implement Merge Sort to sort the linked list. This algorithm is a natural fit for list structures.
+ b) This implementation must also use the public/private recursion pattern.
+ c) Hint: For splitting the linked list, research the "fast and slow pointer" technique.
+
+Part 4: The Great Sort-Off
+It's time for a performance battle! You will use your TSort engine to sort the same large dataset with all your implemented algorithms and analyze the results.
+
+8. Callback Implementations:
+ a) Write at least two different FCompareAccounts callback functions: one to sort by last name, and one to sort by balance.
+
+9. The Performance Battle:
+ a) Using your dataset of 5,000+ accounts, run all four of your sorting algorithms using the same callback function for a fair comparison.
+ b) For each run, capture the OperationSummary (comparisons, swaps, time).
+
+10. Analysis in Your Report:
+ a) Present your performance data in a clear table.
+ b) Write a paragraph answering: How do the results illustrate the difference between O(n²) and O(n log n) complexity? Why was Selection Sort harder on a list versus an array?
+
+Part 5: The Payoff - Integrated Binary Search
+
+11. The Integrated BinarySearch() Method:
+ a) Add a BinarySearch() method to your TSort class. This method will operate on a sorted array.
+ b) The TSort class must now manage an internal state (e.g., a private pointer to a sorted array and a boolean flag). A sorting method like SortArrayByLastName() will now create the sorted array, store it internally, and set the flag.
+ c) The BinarySearch() method must first check this internal flag to ensure the data is sorted before proceeding.
+ d) It must use the public/private recursion pattern and accept an FCompareAccounts callback to guide the search.
+
+12. Final Demonstration & Comparison:
+ a) In main(), first call one of your array sorting methods on your TSort instance. Then, use its new BinarySearch() method to find an item.
+ b) In your report, create a small final table comparing the number of comparisons to find the same item using:
+ 1. The Linear Search from Submission 4.
+ 2. The Binary Search from this submission.
+ c) This result is the ultimate conclusion to your work on searching and sorting!
+*/
+
+
+typedef int (*FCompareAccounts)(TBankAccount*, TBankAccount*);
+
+class TSort
+{
+private:
+ TLinkedList* list;
+ TBankAccount** array;
+ int size;
+
+ TBankAccount** sortedArray; // Internal pointer to the sorted array
+ bool isSorted; // Flag to check if sorting has been done
+
+ void swap(TBankAccount* a, TBankAccount* b) {
+ TBankAccount* temp = a;
+ a = b;
+ b = temp;
+ statistics.swaps++;
+ }
+
+ int Partition(TBankAccount** aArray, int aLow, int aHigh, FCompareAccounts aCompareFunc) {
+ TBankAccount* pivot = aArray[aHigh];
+ int i = (aLow - 1);
+ for (int j = aLow; j <= aHigh - 1; j++) {
+ statistics.comparisonCount++;
+ if (aCompareFunc(aArray[j], pivot) < 0) {
+ i++;
+ swap(aArray[i], aArray[j]);
+ TBankAccount* temp = aArray[i];
+ aArray[i] = aArray[j];
+ aArray[j] = temp;
+ }
+ }
+ swap(aArray[i + 1], aArray[aHigh]);
+ TBankAccount* temp = aArray[i + 1];
+ aArray[i + 1] = aArray[aHigh];
+ aArray[aHigh] = temp;
+ return (i + 1);
+ }
+
+ void QuickSortRecursive(TBankAccount** aArray, int aLow, int aHigh, FCompareAccounts aCompareFunc) {
+ if (aLow < aHigh) {
+ int pi = Partition(aArray, aLow, aHigh, aCompareFunc);
+ QuickSortRecursive(aArray, aLow, pi - 1, aCompareFunc);
+ QuickSortRecursive(aArray, pi + 1, aHigh, aCompareFunc);
+ }
+ }
+
+ // Private helper for MergeSortList: Merges two already sorted lists
+ TLinkedListNode* MergeSortedLists(TLinkedListNode* a, TLinkedListNode* b, FCompareAccounts aCompareFunc) {
+ // Base cases
+ if (a == nullptr) return b;
+ if (b == nullptr) return a;
+
+ TLinkedListNode* resultHead = nullptr;
+ TLinkedListNode* resultTail = nullptr;
+
+ // Set the head of the result list
+ statistics.comparisonCount++;
+ if (aCompareFunc(a->data, b->data) <= 0) {
+ resultHead = a;
+ a = a->next;
+ }
+ else {
+ resultHead = b;
+ b = b->next;
+ }
+ resultTail = resultHead; // The tail is currently the head
+
+ // Loop through the rest of the lists
+ while (a != nullptr && b != nullptr) {
+ statistics.comparisonCount++;
+ if (aCompareFunc(a->data, b->data) <= 0) {
+ resultTail->next = a;
+ resultTail = a;
+ a = a->next;
+ }
+ else {
+ resultTail->next = b;
+ resultTail = b;
+ b = b->next;
+ }
+ }
+
+ // Attach the remaining list (if any)
+ if (a != nullptr) {
+ resultTail->next = a;
+ }
+ else if (b != nullptr) {
+ resultTail->next = b;
+ }
+
+ return resultHead;
+ }
+
+ // Private helper for MergeSortList: Splits a list into two halves
+ // Uses the "fast and slow pointer" technique.
+ // 'source' is the head of the list to split.
+ // Returns the head of the second half. 'source' is modified to be the first half.
+ TLinkedListNode* SplitList(TLinkedListNode* source) {
+ TLinkedListNode* fast;
+ TLinkedListNode* slow;
+ TLinkedListNode* slowPrev = nullptr; // Need this to break the list
+ slow = source;
+ fast = source;
+
+ // Advance 'fast' two steps and 'slow' one step
+ while (fast != nullptr && fast->next != nullptr) {
+ fast = fast->next->next;
+ slowPrev = slow;
+ slow = slow->next;
+ }
+
+ // 'slow' is now at or near the middle.
+ // Split the list in two by setting the end of the first list to null.
+ if (slowPrev != nullptr) {
+ slowPrev->next = nullptr;
+ }
+
+ // 'slow' is the head of the second list
+ return slow;
+ }
+
+ void MergeSortRecursive(TLinkedListNode** aHeadRef, FCompareAccounts aCompareFunc) {
+ TLinkedListNode* head = *aHeadRef;
+ TLinkedListNode* left;
+ TLinkedListNode* right;
+
+ // Base case: 0 or 1 element list is already sorted
+ if (head == nullptr || head->next == nullptr) {
+ return;
+ }
+
+ // 1. Split the list into 'left' and 'right' halves
+ left = head;
+ right = SplitList(head); // 'head' (now 'left') is modified to be the first half
+
+ // 2. Recursively sort the two halves
+ MergeSortRecursive(&left, aCompareFunc);
+ MergeSortRecursive(&right, aCompareFunc);
+
+ // 3. Merge the two sorted halves back together
+ // Update the head pointer to point to the new sorted list
+ *aHeadRef = MergeSortedLists(left, right, aCompareFunc);
+ }
+
+ TBankAccount* BinarySearchRecursive(TBankAccount* aKey, FCompareAccounts aCompareFunc, int aLow, int aHigh)
+ {
+ // Base case: Not found
+ if (aLow > aHigh) {
+ return nullptr;
+ }
+
+ int mid = aLow + (aHigh - aLow) / 2;
+
+ // Use the callback to compare the array element with the key
+ // We assume the callback knows what field to compare (e.g., lastName)
+ statistics.comparisonCount++; // Track comparisons
+ int comparisonResult = aCompareFunc(sortedArray[mid], aKey);
+
+ if (comparisonResult == 0) {
+ return sortedArray[mid]; // Found
+ }
+ else if (comparisonResult < 0) {
+ // sortedArray[mid] is *before* aKey, so search the right half
+ return BinarySearchRecursive(aKey, aCompareFunc, mid + 1, aHigh);
+ }
+ else {
+ // sortedArray[mid] is *after* aKey, so search the left half
+ return BinarySearchRecursive(aKey, aCompareFunc, aLow, mid - 1);
+ }
+ }
+
+
+public:
+ TSort(TLinkedList* aList, TBankAccount** aArray) : list(aList), array(aArray) {
+ size = list->getSize();
+ sortedArray = nullptr;
+ isSorted = false;
+ }
+ ~TSort() {}
+
+ TBankAccount** SelectionSortArray(FCompareAccounts compare) {
+ std::cout << "Starting Selection Sort on Array..." << std::endl;
+ resetStatistics();
+ sortedArray = new TBankAccount * [size];
+ for (int i = 0; i < size; i++) {
+ sortedArray[i] = array[i];
+ }
+ for (int i = 0; i < size - 1; i++) {
+ int minIndex = i;
+ for (int j = i + 1; j < size; j++) {
+ statistics.comparisonCount++;
+ if (compare(sortedArray[j], sortedArray[minIndex]) < 0) {
+ minIndex = j;
+ }
+ }
+ if (minIndex != i) {
+ swap(sortedArray[i], sortedArray[minIndex]);
+ TBankAccount* temp = sortedArray[i];
+ sortedArray[i] = sortedArray[minIndex];
+ sortedArray[minIndex] = temp;
+ }
+ }
+ printStastics();
+ isSorted = true; // Mark as sorted
+ return sortedArray;
+ }
+
+ TLinkedList* SelectionSortList(FCompareAccounts aCompareFunc) {
+ std::cout << "Starting Selection Sort on Linked List..." << std::endl;
+ resetStatistics();
+ TLinkedList* sortedList = new TLinkedList(false); // New list does not own data
+ TLinkedList* tempList = new TLinkedList(false); // Temporary list to hold unsorted data
+ for (int i = 0; i < size; i++) {
+ tempList->Add(array[i]);
+ }
+
+ // Start at the first real node (head->next)
+ TLinkedListNode* current = tempList->getHead() ? tempList->getHead()->next : nullptr;
+ while (current) {
+ // find minimum starting from 'current'
+ TLinkedListNode* minNode = current;
+ TLinkedListNode* iter = current;
+ while (iter) {
+ statistics.comparisonCount++;
+ // guard against null data pointers
+ if (iter->data && minNode->data && aCompareFunc(iter->data, minNode->data) < 0) {
+ minNode = iter;
+ }
+ iter = iter->next;
+ }
+
+ if (minNode && minNode->data) {
+ // Append to keep ascending order (Add prepends and would reverse)
+ sortedList->Append(minNode->data);
+ tempList->Remove(minNode->data);
+ statistics.swaps++;
+ }
+
+ // restart search from first real node again
+ current = tempList->getHead() ? tempList->getHead()->next : nullptr;
+ }
+ printStastics();
+ delete tempList;
+ return sortedList;
+ }
+ // Bubble Sort for array, Time Complexity O(n^2), space O(1)
+ TBankAccount** BubbleSortArray(FCompareAccounts compare) {
+ std::cout << "Starting Bubble Sort on Array..." << std::endl;
+ resetStatistics();
+ sortedArray = new TBankAccount * [size];
+ for (int i = 0; i < size; i++) {
+ sortedArray[i] = array[i];
+ }
+ for (int i = 0; i < size - 1; i++) {
+ for (int j = 0; j < size - i - 1; j++) {
+ statistics.comparisonCount++;
+ if (compare(sortedArray[j], sortedArray[j + 1]) > 0) {
+ swap(sortedArray[j], sortedArray[j + 1]);
+ TBankAccount* temp = sortedArray[j];
+ sortedArray[j] = sortedArray[j + 1];
+ sortedArray[j + 1] = temp;
+ }
+ }
+ }
+ printStastics();
+ isSorted = true; // Mark as sorted
+ return sortedArray;
+ }
+
+ // Bubble Sort for linked list, Time Complexity O(n^2), space O(1)
+ TLinkedList* BubbleSortList(FCompareAccounts aCompareFunc) {
+ std::cout << "Starting Bubble Sort on Linked List..." << std::endl;
+ resetStatistics();
+ TLinkedList* sortedList = new TLinkedList(false); // New list does not own data
+ TLinkedList* tempList = new TLinkedList(false); // Temporary list to hold unsorted data
+ for (int i = 0; i < size; i++) {
+ tempList->Add(array[i]);
+ }
+ int n = tempList->getSize();
+
+ // Start at first real node (skip dummy head)
+ TLinkedListNode* current;
+ TLinkedListNode* nextNode;
+ for (int i = 0; i < n - 1; i++) {
+ // Reset current to the start of the list for each outer loop
+ current = tempList->getHead() ? tempList->getHead()->next : nullptr;
+ nextNode = current ? current->next : nullptr;
+ for (int j = 0; j < n - i - 1; j++) {
+ if (!current || !nextNode) break;
+ statistics.comparisonCount++;
+ // Defensive: guard against null node->data
+ if (current->data && nextNode->data && aCompareFunc(current->data, nextNode->data) > 0) {
+ // Single correct swap of pointers
+ std::swap(current->data, nextNode->data);
+ statistics.swaps++;
+ }
+ current = nextNode;
+ nextNode = nextNode->next;
+ }
+ }
+
+ // Transfer sorted data (append to preserve order)
+ current = tempList->getHead() ? tempList->getHead()->next : nullptr;
+ while (current) {
+ sortedList->Append(current->data);
+ current = current->next;
+ }
+
+ delete tempList;
+ printStastics();
+ return sortedList;
+ }
+
+ TBankAccount** QuickSortArray(FCompareAccounts aCompare) {
+ std::cout << "Starting Quick Sort on Array..." << std::endl;
+ sortedArray = new TBankAccount * [size];
+ for (int i = 0; i < size; i++) {
+ sortedArray[i] = array[i];
+ }
+ resetStatistics();
+ // Call the recursive QuickSort function
+ QuickSortRecursive(sortedArray, 0, size - 1, aCompare);
+ printStastics();
+ isSorted = true; // Mark as sorted
+ return sortedArray;
+ }
+
+ TLinkedList* MergeSortList(FCompareAccounts aCompareFunc) {
+ std::cout << "Starting Merge Sort on Linked List..." << std::endl;
+ resetStatistics(); // Resets comparisons, swaps, and starts timer
+
+ // 1. Create the new list that we will sort and return.
+ // It does not own the TBankAccount data.
+ TLinkedList* sortedList = new TLinkedList(false);
+ if (size == 0) {
+ printStastics();
+ return sortedList; // Return empty list if source is empty
+ }
+
+ // 2. Populate 'sortedList' with the data from the array.
+ // We use 'Add' (prepend) for consistency with your other list sort methods.
+ // The initial order doesn't matter, as we're sorting the whole set.
+ for (int i = 0; i < size; i++) {
+ sortedList->Add(array[i]);
+ }
+
+ // 3. Get the address of the *real* head pointer (head->next).
+ // The list uses a dummy head, so sorting starts at 'head->next'.
+ // The recursive function needs a pointer-to-a-pointer
+ // so it can modify which node is the *new* first node.
+ TLinkedListNode** realHeadPtr = &(sortedList->getHead()->next);
+
+ // 4. Call the recursive sort.
+ // This will sort the list 'in-place' by rearranging node pointers.
+ MergeSortRecursive(realHeadPtr, aCompareFunc);
+
+ // 5. Print statistics and return the now-sorted list
+ // Note: MergeSort by node-relinking doesn't use "swaps"
+ // in the traditional sense, so statistics.swaps should be 0.
+ printStastics();
+ return sortedList;
+ }
+
+ // Public method to start the Binary Search
+ TBankAccount* BinarySearch(TBankAccount* aKey, FCompareAccounts aCompareFunc)
+ {
+ // Check the flag as required by the prompt
+ if (!isSorted || sortedArray == nullptr) {
+ std::cout << "Error: Cannot binary search. Array is not sorted." << std::endl;
+ std::cout << "Please call an array-sorting method (e.g., QuickSortArray) first." << std::endl;
+ return nullptr;
+ }
+
+ std::cout << "Starting Binary Search..." << std::endl;
+ // We reset statistics *only* for the search operation
+ resetStatistics();
+
+ TBankAccount* foundAccount = BinarySearchRecursive(aKey, aCompareFunc, 0, size - 1);
+
+ printStastics(); // Print search performance
+ return foundAccount;
+ }
+
+};
+
+// Comparison functions
+// Comapre based on account number
+static int CompareByAccountNumber(TBankAccount* a, TBankAccount* b) {
+ return a->getAccountNumber().compare(b->getAccountNumber());
+}
+
+//Cmpare based on creation timestamp
+static int CompareByCreationTimestamp(TBankAccount* a, TBankAccount* b) {
+ if (a->getCreationTimestamp() < b->getCreationTimestamp()) return -1;
+ if (a->getCreationTimestamp() > b->getCreationTimestamp()) return 1;
+ return 0;
+}
+
+// Compare by last name (alphabetical)
+static int CompareByLastName(TBankAccount* a, TBankAccount* b) {
+ return a->ownerLastName.compare(b->ownerLastName);
+}
+
+// Compare by balance (lowest to highest)
+static int CompareByBalance(TBankAccount* a, TBankAccount* b) {
+ if (a->getBalance() < b->getBalance()) return -1;
+ if (a->getBalance() > b->getBalance()) return 1;
+ return 0;
+}
+
+static bool Print15Accounts(TBankAccount* account, int index) {
+ if (index < 15) {
+ std::cout << account->getAccountNumber() << std::endl;
+ return true; // Continue
+ }
+ return false; // Stop
+}
+
+
+
+int main()
+{
+ std::cout << "--- Submission 5: The Algorithmic Organizer ---" << std::endl;
+ std::string namesFile = "F:\\IKT203\\VisualStudio\\DATA\\Random_Name.txt";
+ std::cout << "Reading names from file: " << namesFile << std::endl;
+ readNamesFromFile(namesFile, OnNameRead);
+ std::cout << "Total Bank Accounts Created: " << bankAccounts->getSize() << std::endl;
+ std::cout << "Converting linked list to array..." << std::endl;
+ bankAccountArray = bankAccounts->ToArray();
+ std::cout << "Array created with " << bankAccounts->getSize() << " accounts." << std::endl;
+
+ TSort sorter(bankAccounts, bankAccountArray);
+ TBankAccount** sortedArray = nullptr;
+ TLinkedList* sortedList = nullptr;
+ sortedArray = sorter.SelectionSortArray(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Selection Sort on Array):" << std::endl;
+ for (int i = 0; i < 15; i++) {
+ std::cout << sortedArray[i]->getAccountNumber() << std::endl;
+ }
+ //Free sorted array
+ delete[] sortedArray;
+
+ sortedList = sorter.SelectionSortList(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Selection Sort on Linked List):" << std::endl;
+ sortedList->Every(Print15Accounts);
+ //Free sorted list
+ delete sortedList;
+
+ sortedArray = sorter.BubbleSortArray(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Bubble Sort on Array):" << std::endl;
+ for (int i = 0; i < 15; i++) {
+ std::cout << sortedArray[i]->getAccountNumber() << std::endl;
+ }
+ //Free sorted array
+ delete[] sortedArray;
+
+ sortedList = sorter.BubbleSortList(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Bubble Sort on Linked List):" << std::endl;
+ sortedList->Every(Print15Accounts);
+ //Free sorted list
+ delete sortedList;
+
+ sortedArray = sorter.QuickSortArray(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Quick Sort on Array):" << std::endl;
+ for (int i = 0; i < 15; i++) {
+ std::cout << sortedArray[i]->getAccountNumber() << std::endl;
+ }
+ //Free sorted array
+ delete[] sortedArray;
+
+ sortedList = sorter.MergeSortList(CompareByAccountNumber);
+ //Print th first 15 sorted account numbers
+ std::cout << "First 15 sorted account numbers (Merge Sort on Linked List):" << std::endl;
+ sortedList->Every(Print15Accounts);
+ //Free sorted list
+ delete sortedList;
+
+ // --- Part 5: The Payoff (Binary Search) ---
+ std::cout << "\n--- Part 5: The Payoff (Binary Search) ---" << std::endl;
+ // We will search for the person from the 100th account in the *original* array
+ // This gives us a random target to find.
+ std::string targetLastName = bankAccountArray[100]->ownerLastName;
+ std::string targetFirstName = bankAccountArray[100]->ownerFirstName;
+ std::cout << "Attempting to find account for: " << targetFirstName << " " << targetLastName << std::endl;
+
+ // 1. Create a "dummy" key object.
+ // We only need to fill in the field we are comparing against (lastName).
+ // We pass 0 (Checking) as a placeholder.
+ TBankAccount* searchKey = new TBankAccount(Checking, "", targetLastName);
+
+ // 2. First, we must sort the array by last name to prepare for binary search.
+ sortedArray = sorter.QuickSortArray(CompareByLastName);
+
+ // 2. Perform the Binary Search
+ // We MUST use the *same comparison function* that the array was sorted with.
+ TBankAccount* foundAccount = sorter.BinarySearch(searchKey, CompareByLastName);
+
+ if (foundAccount != nullptr) {
+ std::cout << "Success! Found account: " << std::endl;
+ foundAccount->printAccountInfo();
+ }
+ else {
+ std::cout << "Failure: Account not found." << std::endl;
+ }
+
+ // 3. Clean up the dummy key
+ delete searchKey;
+ // Clean up the sorted array
+ delete[] sortedArray;
+
+
+ // Cleanup
+ // First delete the array, then the linked list
+ delete[] bankAccountArray;
+ delete bankAccounts;
+
+ return 0;
+}
+
+/*
+Report Analysis Text (Part 4)
+
+Here is a sample table and analysis paragraph as required by the assignment prompt.
+
+Performance Battle: Sorting 2500 Accounts by Last Name
+
+Algorithm Data Structure Comparisons Swaps Time
+Selection Sort Array ~3,123,750 ~2,499 ~2.8 s
+Bubble Sort Array ~3,123,750 ~1,500,000 ~2.5 s
+Quick Sort Array ~32,000 ~15,000 ~0.02 s
+Merge Sort Linked List ~25,000 0 ~0.02 s
+
+(Note: Actual numbers will vary slightly, but the magnitude will be the same.)
+
+Analysis of O(n²) vs. O(n log n):
+
+The performance data clearly illustrates the massive theoretical difference between O(n²) and O(n log n) complexity.
+The O(n²) algorithms (Selection, Bubble) both required over 3.1 million comparisons, which is consistent with the (n * (n-1)) / 2 formula.
+In contrast, the O(n log n) algorithms (Quick, Merge) required only ~25-30,000 comparisons. This huge reduction in operations resulted in a runtime improvement of over 100x (from ~2.6 seconds to ~0.02 seconds).
+This demonstrates that for a dataset of just 2500 items, the choice of a "Divide and Conquer" algorithm is not a minor optimization but a fundamental requirement for acceptable performance.
+
+Why was Selection Sort harder on a list versus an array?
+
+(This question is in your prompt, but your log shows the list version was faster! This is likely due to your specific Remove implementation. The classic answer is below, which you can adapt.)
+
+Classic Answer: Implementing Selection Sort on a linked list is conceptually harder and often slower than on an array.
+In an array, "swapping" elements is a trivial O(1) operation (std::swap(arr[i], arr[min])). In a linked list, a "swap" is complex.
+To move a node, you must find the node before it and meticulously relink four pointers (e.g., prevMin->next, minNode->next, etc.) without losing any part of the list.
+This pointer manipulation is far more complex and error-prone than a simple array index swap. (In our implementation, we "swapped" by removing the node and appending it, which still involves list traversal and is less efficient than an array swap.)
+
+Report Analysis Text (Part 5)
+
+Search Performance Comparison: Finding One Account in 2500
+Search Algorithm Data Structure Comparisons (Approx.)
+Linear Search Unsorted Array/List ~1250 (Average Case)
+Binary Search Sorted Array ~11-12
+
+Analysis:
+
+This result is the ultimate payoff for sorting.
+A linear search on our 2500-item unsorted list would, on average, require checking half the items (n/2, or ~1250 comparisons) and in the worst case 2500 (n).
+After sorting the data just once (an O(n log n) cost), we can now find any item using Binary Search. This O(log n) algorithm reduced the search comparisons from ~1250 to just 12 (logâ(2500) â 11.3).
+This is an exponential speedup, making data retrieval virtually instantaneous, and it proves why sorting is a foundational prerequisite for efficient data processing.
+*/
+
+/*
+Logg from running the program:
+
+--- Submission 5: The Algorithmic Organizer ---
+Reading names from file: F:\IKT203\VisualStudio\DATA\Random_Name.txt
+Total Bank Accounts Created: 2500
+Converting linked list to array...
+Array created with 2500 accounts.
+Starting Selection Sort on Array...
+Comparisons: 3123750, Swaps: 2494, Time taken : 2.927 seconds.
+First 15 sorted account numbers (Selection Sort on Array):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+Starting Selection Sort on Linked List...
+Comparisons: 3126250, Swaps: 2500, Time taken : 2.685 seconds.
+First 15 sorted account numbers (Selection Sort on Linked List):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+Starting Bubble Sort on Array...
+Comparisons: 3123750, Swaps: 1579132, Time taken : 2.501 seconds.
+First 15 sorted account numbers (Bubble Sort on Array):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+Starting Bubble Sort on Linked List...
+Comparisons: 3123750, Swaps: 1544618, Time taken : 2.536 seconds.
+First 15 sorted account numbers (Bubble Sort on Linked List):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+Starting Quick Sort on Array...
+Comparisons: 32501, Swaps: 15752, Time taken : 0.023 seconds.
+First 15 sorted account numbers (Quick Sort on Array):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+Starting Merge Sort on Linked List...
+Comparisons: 25093, Swaps: 0, Time taken : 0.018 seconds.
+First 15 sorted account numbers (Merge Sort on Linked List):
+1006.19.41937
+1009.29.37840
+1026.96.17049
+1033.96.20263
+1035.79.40057
+1037.13.26840
+1037.49.34641
+1038.73.38621
+1042.95.36093
+1043.63.17037
+1044.55.24939
+1049.32.31466
+1050.25.30388
+1060.62.29640
+1064.57.36126
+
+--- Part 5: The Payoff (Binary Search) ---
+Attempting to find account for: Avyan Byerly
+Starting Quick Sort on Array...
+Comparisons: 38457, Swaps: 15141, Time taken : 0.001 seconds.
+Starting Binary Search...
+Comparisons: 8, Swaps: 0, Time taken : 0 seconds.
+Success! Found account:
+Account Number: 1978.66.25918, Type: Checking, Owner: Avyan Byerly, Balance: 507, Created: Sun Oct 27 18:56:00 2024
+
+
+*/
\ No newline at end of file
diff --git a/Exam/IKT203Exam/Submissions/Submission-05/main.h b/Exam/IKT203Exam/Submissions/Submission-05/main.h
new file mode 100644
index 0000000..ccf6e27
--- /dev/null
+++ b/Exam/IKT203Exam/Submissions/Submission-05/main.h
@@ -0,0 +1,8 @@
+// Submission-01.h : Include file for standard system include files,
+// or project specific include files.
+
+#pragma once
+
+#include
+
+// TODO: Reference additional headers your program requires here.
diff --git a/Fundamental_Recursion/CMakeLists.txt b/Fundamental_Recursion/CMakeLists.txt
deleted file mode 100644
index 7147ef8..0000000
--- a/Fundamental_Recursion/CMakeLists.txt
+++ /dev/null
@@ -1,10 +0,0 @@
-cmake_minimum_required(VERSION 4.0)
-project(Fundamental_Recursion)
-
-set(CMAKE_CXX_STANDARD 20)
-
-add_executable(Fundamental_Recursion
- main.cpp
- utils.cpp
- Utils.h
-)
diff --git a/Fundamental_Recursion/Utils.cpp b/Fundamental_Recursion/Utils.cpp
deleted file mode 100644
index 96c42cc..0000000
--- a/Fundamental_Recursion/Utils.cpp
+++ /dev/null
@@ -1,132 +0,0 @@
-#include
-#include
-#include
-#include "Utils.h"
-
-void printNaturalNumber(const int n)
-{
- if (n == 0)
- return;
- // "Digs down" until n = 0, then prints all natural numbers on the way back up
- printNaturalNumber(n-1);
- std::cout << n << " ";
-}
-
-int calculateFactorial(const int n)
-{
- if (n <= 1)
- return 1;
- // "Digs down" until n <= 1, then multiplies by n for every step back up
- return n * calculateFactorial(n-1);
-}
-
-int power(const int base,const int exp)
-{
- if (exp == 0 || base == 1 || base == 0)
- return 1;
- // "Digs down" until exp <= 0, then multiplies base with the base for every step back up
- return base * power(base, exp - 1); // The simplest to write, not the most efficient - O(n)
-
- // int half = power(base / 2, exp);
- // if (exp % 2 == 0)
- // return half * half;
- // else
- // return base * half * half; // More efficient implementation, reduces the recursive call by half
- // O(log n)
-
-}
-
-int fibonacci(const int n)
-{
- if (n == 0)
- return 0;
- if (n == 1)
- return 1;
- return fibonacci(n - 1) + fibonacci(n - 2); // O(2^n), each call spawns two more recursive calls
- // Could be optimised by using iteration instead of recursion
- // For loop would be O(n) since it takes the previous number, adding
- // current number, then stepping up until it has iterated n times
- // Linear growth instead of exponential
- // int current = 1;
- // int previous = 0;
- // for (int i = 2; i <= n; i++)
- // {
- // int next = previous + current;
- // previous = current;
- // current = next;
- // }
- // return current;
-}
-
-int countOccurrences (const std::string& s, const char c)
-{
- if (s.empty())
- return 0;
- const int count = (s[0] == c ? 1 : 0);
- return count + countOccurrences(s.substr(1), c);
- // O(n^2) since we have to make a new substring for every index of the original string
-}
-
-int findLargestElement(const int arr[], const int size)
-{
- if (size <= 0)
- return 0;
- if (size == 1)
- return arr[0];
- const int mid = size / 2;
- const int leftMax = findLargestElement(arr, mid);
- const int rightMax = findLargestElement(arr + mid, size - mid);
-
- return (leftMax > rightMax) ? leftMax : rightMax;
- // O(n) time complexity, since we have to compare each element at least once
-}
-
-// Up to, not including, end
-void traverseAsciiTable(const char start, const char end)
-{
- if (start >= end)
- return;
- std::cout << start << " "; // Reflects the building
- traverseAsciiTable(static_cast(start + 1), end);
-
- std::cout << " "; // Reflects the unwinding
-}
-
-// Helper funcs to populate and randomise input
-
-void fillRandomArray(int arr[], const int size, const int minVal, const int maxVal)
-{
- std::random_device rd;
- std::mt19937 gen(rd());
- std::uniform_int_distribution<> dist(minVal, maxVal);
-
- for (int i = 0; i < size; i++)
- {
- arr[i] = dist(gen);
- }
-}
-
-std::string makeRandomString(const int len, char minChar = 'a', char maxChar = 'z')
-{
- if (len <= 0)
- return{};
- std::random_device rd;
- std::mt19937 gen(rd());
- std::uniform_int_distribution dist(minChar, maxChar);
-
- std::string s;
- s.reserve(len);
- for (int i = 0; i < len; i++)
- s.push_back(static_cast(dist(gen)));
- return s;
-}
-
-int countOccurrences_index(const std::string& s, const char c, int index)
-{
- if (index >= static_cast(s.size()))
- return 0;
- const int hit = (s[index] == c ? 1 : 0);
- return hit + countOccurrences_index(s, c, index + 1);
-}
-
-
diff --git a/Fundamental_Recursion/Utils.h b/Fundamental_Recursion/Utils.h
deleted file mode 100644
index a8ce3ae..0000000
--- a/Fundamental_Recursion/Utils.h
+++ /dev/null
@@ -1,33 +0,0 @@
-#ifndef FUNDAMENTAL_RECURSION_UTILS_H
-#define FUNDAMENTAL_RECURSION_UTILS_H
-
-#include
-#include
-
-
-void printNaturalNumber(int n);
-int calculateFactorial(int n);
-int power(int base, int exp);
-int fibonacci(int n);
-int countOccurrences(const std::string& s, char c);
-int findLargestElement(const int arr[], int size);
-void traverseAsciiTable(char start, char end);
-
-
-// Helpers partially generated by ChatGPT
-void fillRandomArray(int arr[], int size, int minVal, int maxVal);
-std::string makeRandomString(int len, char minChar, char maxChar);
-int countOccurrences_index(const std::string& s, char c, int index);
-
-template
-double time_ms(F&& f, Args&&... args)
-{
- auto t0 = std::chrono::high_resolution_clock::now();
- (void)std::forward(f)(std::forward(args)...);
- auto t1 = std::chrono::high_resolution_clock::now();
- return std::chrono::duration(t1 - t0).count();
-}
-
-
-
-#endif //FUNDAMENTAL_RECURSION_UTILS_H
\ No newline at end of file
diff --git a/Fundamental_Recursion/main.cpp b/Fundamental_Recursion/main.cpp
deleted file mode 100644
index 30a3e9c..0000000
--- a/Fundamental_Recursion/main.cpp
+++ /dev/null
@@ -1,89 +0,0 @@
-#include
-#include
-#include "Utils.h"
-
-static void line(const char* title)
-{
- std::cout << "\n======= " << title << "=======\n";
-}
-
-int main()
-{
- line("Neutral numbers");
- printNaturalNumber(10);
- std::cout << "\n";
-
-
- line("Factorial");
- const int fact_expect[] = {
- 1, 1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800
- };
- bool ok_fact = true;
- for (int n = 0; n <= 10; ++n) {
- int r = calculateFactorial(n);
- std::cout << "n=" << n << " -> " << r
- << (r == fact_expect[n] ? " OK" : " MISMATCH") << "\n";
- ok_fact &= (r == fact_expect[n]);
- }
-
-
- line ("Power");
- struct Case { int base, exp, expect; };
- const Case pow_cases[] = {
- {2,0,1}, {2,1,2}, {2,5,32}, {3,4,81}, {5,3,125}, {10,2,100}
- };
- bool ok_pow = true;
- for (auto c : pow_cases) {
- int r = power(c.base, c.exp);
- std::cout << c.base << "^" << c.exp << " = " << r
- << (r == c.expect ? " OK" : " MISMATCH") << "\n";
- ok_pow &= (r == c.expect);
-
- line("Fibonacci");
- const int fib_expect[] = {0,1,1,2,3,5,8,13,21,34,55,89,144};
- bool ok_fib = true;
- for (int n = 0; n <= 12; ++n) {
- int r = fibonacci(n);
- std::cout << "F(" << n << ") = " << r
- << (r == fib_expect[n] ? " OK" : " MISMATCH") << "\n";
- ok_fib &= (r == fib_expect[n]);
- }
-
-
- line("Count occurrences");
- std::string s = makeRandomString(2000, 'a', 'f');
- char target = 'c';
- int rec = countOccurrences(s, target); //<--- recursive
- int ref = static_cast(std::count(s.begin(), s.end(), target));
- std::cout << "recursive=" << rec << " std::count=" << ref
- << (rec == ref ? " OK" : " MISMATCH") << "\n";
- double t_rec_ms = time_ms([&]{ (void)countOccurrences(s, target); });
- std::cout << "perf (recursive substr): ~" << t_rec_ms << " ms\n";
-
-
- line ("Find largest element");
- constexpr int N = 100000;
- int* arr = new int[N];
- fillRandomArray(arr, N, -100000, 100000);
- double t_my_ms = time_ms([&]{ (void)findLargestElement(arr, N); });
- int myMax = findLargestElement(arr, N);
- int stdMax = *std::max_element(arr, arr + N);
- std::cout << "myMax=" << myMax << " stdMax=" << stdMax
- << (myMax == stdMax ? " OK" : " MISMATCH") << "\n";
- std::cout << "perf (recursive): ~" << t_my_ms << " ms\n";
- delete[] arr;
-
-
- line("Traverse Ascii table");
- traverseAsciiTable('A', 'F');
- std::cout << "\n";
-
-
- line("Summary");
- std::cout << "Factorial: " << (ok_fact ? "OK" : "FAIL") << "\n";
- std::cout << "Power: " << (ok_pow ? "OK" : "FAIL") << "\n";
- std::cout << "Fibonacci: " << (ok_fib ? "OK" : "FAIL") << "\n";
-
- return 0;
- }
-}
\ No newline at end of file
diff --git a/Stacks&Queues/CMakeLists.txt b/Stacks&Queues/CMakeLists.txt
deleted file mode 100644
index 0905ef2..0000000
--- a/Stacks&Queues/CMakeLists.txt
+++ /dev/null
@@ -1,11 +0,0 @@
-cmake_minimum_required(VERSION 4.0)
-project(Stacks_Queues)
-
-set(CMAKE_CXX_STANDARD 20)
-
-add_executable(Stacks_Queues main.cpp
- TStack.cpp
- TStack.h
- TQueue.cpp
- TQueue.h
- FUtils.h)
diff --git a/Stacks&Queues/FUtils.h b/Stacks&Queues/FUtils.h
deleted file mode 100644
index b442cdf..0000000
--- a/Stacks&Queues/FUtils.h
+++ /dev/null
@@ -1,183 +0,0 @@
-#ifndef STACKS_QUEUES_FUTILS_H
-#define STACKS_QUEUES_FUTILS_H
-
-#include
-#include
-#include
-#include "TQueue.h"
-#include "TStack.h"
-
-constexpr int GRID_ROWS = 100;
-constexpr int GRID_COLS = 100;
-
-
-// Stack is perfect here because of the structure and behaviour of stacks - LIFO
-// When we push the string in it will send the first char to the bottom of the stack
-// When we push the string back out it will pop the last char first, then the second to last, then third and so on
-// Time and space complexity is O(n) - each char pushed and popped exactly once and
-// helper string "reverse clone" is needed for output
-inline std::string ReverseString(const std::string& input)
-{
- if (input.size() > MAX_SIZE)
- throw std::overflow_error("Input longer than MAX_SIZE");
- TStack s;
- for (char c : input)
- s.Push(c);
- std::string output;
- output.reserve(input.size());
- while (!s.IsEmpty())
- {
- output.push_back(s.Pop());
- }
- return output;
-}
-
-// Time = O(n) - push 2 .. n once and pop each once
-// Space = O(1) - fixed size array inside TStack
-inline long long Factorial(const int base)
-{
- if (base < 0)
- throw std::invalid_argument("n must be >= 0");
- if (base == 0 || base == 1)
- return 1;
- if (base > MAX_SIZE)
- throw std::overflow_error("n exceeds MAX_SIZE");
- TStack s;
- for (int i = 2; i <= base; ++i)
- s.Push(i);
- long long result = 1;
- while (!s.IsEmpty())
- result *= s.Pop();
- return result;
-}
-
-// Time = O(arrivals + toServe)
-// Space = O(1) - fixed size queue
-inline void SimulateWaitLine(const int arrivals, int toServe, TQueue& queue)
-{
- static int nextId = 1;
- // arrivals
- for (int i = 1; i <= arrivals; ++i) {
- queue.Enqueue(nextId);
- std::cout << "Arrives: " << nextId << std::endl;
- nextId++;
- }
-
- // served
- for (int i = 0; i < toServe && !queue.IsEmpty(); ++i) {
- std::cout << "Served: " << queue.Dequeue() << std::endl;
- }
-}
-
-// O(1) both - just checking if true or false
-inline bool InBounds (int r, int c)
-{
- return r >= 0 && r < GRID_ROWS && c >= 0 && c < GRID_COLS;
-}
-
-// O(r * c)
-inline void ResetVisited(bool visited[GRID_ROWS][GRID_COLS])
-{
- for (int r = 0; r < GRID_ROWS; ++r) {
- for (int c = 0; c < GRID_COLS; ++c) {
- visited[r][c] = false;
- }
- }
-}
-
-inline int EncodePos(int r, int c) {
- return r * GRID_COLS + c;
-}
-
-inline void DecodePos(int code, int& r, int& c) {
- r = code / GRID_COLS;
- c = code % GRID_COLS;
-}
-
-// Time = O( r * c) worst case
-// Space is O(1)
-inline bool DFSFindZero(const int grid[GRID_ROWS][GRID_COLS], bool visited[GRID_ROWS][GRID_COLS],
- int startR, int startC, int& outR, int& outC)
-{
- TStack s;
-
- // mark start immediately to avoid multiple pushes
- visited[startR][startC] = true;
- s.Push(EncodePos(startR, startC));
-
- while (!s.IsEmpty())
- {
- int code = s.Pop();
- int r, c; DecodePos(code, r, c);
-
- if (grid[r][c] == 0) {
- outR = r; outC = c;
- return true;
- }
-
- // Push neighbours, marking visited when discovered
- if (InBounds(r - 1, c) && !visited[r - 1][c]) {
- visited[r - 1][c] = true;
- s.Push(EncodePos(r - 1, c)); // up
- }
- if (InBounds(r, c + 1) && !visited[r][c + 1]) {
- visited[r][c + 1] = true;
- s.Push(EncodePos(r, c + 1)); // right
- }
- if (InBounds(r + 1, c) && !visited[r + 1][c]) {
- visited[r + 1][c] = true;
- s.Push(EncodePos(r + 1, c)); // down
- }
- if (InBounds(r, c - 1) && !visited[r][c - 1]) {
- visited[r][c - 1] = true;
- s.Push(EncodePos(r, c - 1)); // left
- }
- }
- return false;
-}
-
-// Same complexity as DFS
-inline bool BFSFindZero(const int grid[GRID_ROWS][GRID_COLS], bool visited[GRID_ROWS][GRID_COLS],
- int startR, int startC, int& outR, int& outC)
-{
- TQueue q;
-
- // mark start immediately to avoid duplicate enqueues
- visited[startR][startC] = true;
- q.Enqueue(EncodePos(startR, startC));
-
- while (!q.IsEmpty())
- {
- int code = q.Dequeue();
- int r, c; DecodePos(code, r, c);
-
- if (grid[r][c] == 0) {
- outR = r; outC = c;
- return true;
- }
-
- // Enqueue neighbours, marking visited on discovery
- if (InBounds(r - 1, c) && !visited[r - 1][c]) {
- visited[r - 1][c] = true;
- q.Enqueue(EncodePos(r - 1, c)); // up
- }
- if (InBounds(r, c + 1) && !visited[r][c + 1]) {
- visited[r][c + 1] = true;
- q.Enqueue(EncodePos(r, c + 1)); // right
- }
- if (InBounds(r + 1, c) && !visited[r + 1][c]) {
- visited[r + 1][c] = true;
- q.Enqueue(EncodePos(r + 1, c)); // down
- }
- if (InBounds(r, c - 1) && !visited[r][c - 1]) {
- visited[r][c - 1] = true;
- q.Enqueue(EncodePos(r, c - 1)); // left
- }
- }
- return false;
-}
-
-
-
-
-#endif //STACKS_QUEUES_FUTILS_H
\ No newline at end of file
diff --git a/Stacks&Queues/TQueue.h b/Stacks&Queues/TQueue.h
deleted file mode 100644
index 03f3c2d..0000000
--- a/Stacks&Queues/TQueue.h
+++ /dev/null
@@ -1,25 +0,0 @@
-#ifndef STACKS_QUEUES_TQUEUE_H
-#define STACKS_QUEUES_TQUEUE_H
-
-#define MAX_SIZE (100 * 100)
-
-
-class TQueue {
- private:
- int queue[MAX_SIZE] {};
- int head = 0;
- int tail = 0;
- int count = 0;
-
- public:
- TQueue() = default;
- ~TQueue() = default;
-
- void Enqueue(int item);
- int Dequeue();
- [[nodiscard]] int GetTail() const;
- [[nodiscard]] int Peek() const;
- [[nodiscard]] bool IsEmpty() const;
- [[nodiscard]] bool IsFull() const;
-};
-#endif //STACKS_QUEUES_TQUEUE_H
\ No newline at end of file
diff --git a/Stacks&Queues/TStack.cpp b/Stacks&Queues/TStack.cpp
deleted file mode 100644
index 6e94aa5..0000000
--- a/Stacks&Queues/TStack.cpp
+++ /dev/null
@@ -1,43 +0,0 @@
-#include "TStack.h"
-#include
-
-// Time complexity O(1) - always append to the end of the array and use that as the top of the stack
-// Space complexity O(1) - no need to save helper variables, just place on top of existing, size-static stack
-void TStack::Push(const int item)
-{
- if (top >= MAX_SIZE)
- throw std::overflow_error("Stack overflow");
- stack[top++] = item;
-}
-
-
-// Time and space complexity both O(1) - Only works with the top element so if you have
-// 5 or 500 elements in the stack the result will be the same
-// Only returns and removes top element
-int TStack::Pop()
-{
- if (top == 0)
- throw std::underflow_error("Stack underflow");
- return stack[--top];
-}
-
-// Time and space complexity O(1) - only returns the top element
-int TStack::Peek() const
-{
- if (top == 0)
- throw std::underflow_error("Stack underflow");
- return stack[top - 1];
-}
-
-// O(1) for both, checks to see if the stack is empty or not
-// doesn't determine exact amount - just makes sure it has one
-bool TStack::IsEmpty() const
-{
- return top == 0;
-}
-
-
-
-
-
-
diff --git a/Stacks&Queues/TStack.h b/Stacks&Queues/TStack.h
deleted file mode 100644
index e9c3c02..0000000
--- a/Stacks&Queues/TStack.h
+++ /dev/null
@@ -1,23 +0,0 @@
-#ifndef STACKS_QUEUES_TSTACK_H
-#define STACKS_QUEUES_TSTACK_H
-
-#define MAX_SIZE (100 * 100)
-
-
-class TStack {
-private:
- int stack[MAX_SIZE]{};
- int top = 0;
-
-public:
- TStack() = default;
- ~TStack() = default;
-
- void Push(int item);
- [[nodiscard]] int Pop();
- [[nodiscard]] int Peek() const;
- [[nodiscard]] bool IsEmpty() const;
-
-};
-
-#endif //STACKS_QUEUES_TSTACK_H
\ No newline at end of file
diff --git a/Stacks&Queues/main.cpp b/Stacks&Queues/main.cpp
deleted file mode 100644
index bac665c..0000000
--- a/Stacks&Queues/main.cpp
+++ /dev/null
@@ -1,48 +0,0 @@
-#include
-#include "FUtils.h"
-
-TQueue q;
-
-int main()
-{
- // --- Part 2: quick demos ---
- std::cout << "Reverse(\"stackqueue\") = " << ReverseString("stackqueue") << "\n";
- std::cout << "Factorial(6) = " << Factorial(6) << "\n";
-
- TQueue q;
- std::cout << "\n-- Wait line simulation --\n";
- SimulateWaitLine(5, 2, q); // 5 arrive, serve 2 now
- SimulateWaitLine(3, 6, q); // 3 arrive, then serve the rest
-
- // --- Part 3.6: set up grid and visited arrays ---
- std::srand(static_cast(std::time(nullptr)));
- int grid[GRID_ROWS][GRID_COLS];
- bool visitedDFS[GRID_ROWS][GRID_COLS];
- bool visitedBFS[GRID_ROWS][GRID_COLS];
-
- for (int r = 0; r < GRID_ROWS; ++r)
- for (int c = 0; c < GRID_COLS; ++c) {
- grid[r][c] = std::rand() % 10; // 0..9
- visitedDFS[r][c] = false;
- visitedBFS[r][c] = false;
- }
-
- int startR = std::rand() % GRID_ROWS;
- int startC = std::rand() % GRID_COLS;
- std::cout << "\nStart cell: (" << startR << ", " << startC
- << ") value=" << grid[startR][startC] << "\n";
-
- // --- Part 3.7: DFS ---
- int dR=-1, dC=-1;
- bool dfsFound = DFSFindZero(grid, visitedDFS, startR, startC, dR, dC);
- if (dfsFound) std::cout << "[DFS] Found 0 at (" << dR << "," << dC << ")\n";
- else std::cout << "[DFS] No 0 found\n";
-
- // --- Part 3.8: BFS ---
- int bR=-1, bC=-1;
- bool bfsFound = BFSFindZero(grid, visitedBFS, startR, startC, bR, bC);
- if (bfsFound) std::cout << "[BFS] Found 0 at (" << bR << "," << bC << ")\n";
- else std::cout << "[BFS] No 0 found\n";
-
- return 0;
-}
\ No newline at end of file
diff --git a/TheAlgorithmicOrganizer/.idea/.gitignore b/TheAlgorithmicOrganizer/.idea/.gitignore
new file mode 100644
index 0000000..13566b8
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/.gitignore
@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/TheAlgorithmicOrganizer/.idea/TheAlgoeithmicOrganizer.iml b/TheAlgorithmicOrganizer/.idea/TheAlgoeithmicOrganizer.iml
new file mode 100644
index 0000000..f08604b
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/TheAlgoeithmicOrganizer.iml
@@ -0,0 +1,2 @@
+
+
\ No newline at end of file
diff --git a/TheAlgorithmicOrganizer/.idea/editor.xml b/TheAlgorithmicOrganizer/.idea/editor.xml
new file mode 100644
index 0000000..9cf688e
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/editor.xml
@@ -0,0 +1,343 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/TheAlgorithmicOrganizer/.idea/material_theme_project_new.xml b/TheAlgorithmicOrganizer/.idea/material_theme_project_new.xml
new file mode 100644
index 0000000..554b701
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/material_theme_project_new.xml
@@ -0,0 +1,12 @@
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/TheAlgorithmicOrganizer/.idea/misc.xml b/TheAlgorithmicOrganizer/.idea/misc.xml
new file mode 100644
index 0000000..0b76fe5
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/misc.xml
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/TheAlgorithmicOrganizer/.idea/modules.xml b/TheAlgorithmicOrganizer/.idea/modules.xml
new file mode 100644
index 0000000..910b840
--- /dev/null
+++ b/TheAlgorithmicOrganizer/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/assignment1/.idea/vcs.xml b/TheAlgorithmicOrganizer/.idea/vcs.xml
similarity index 100%
rename from assignment1/.idea/vcs.xml
rename to TheAlgorithmicOrganizer/.idea/vcs.xml
diff --git a/assignment1/.clang-format b/assignment1/.clang-format
deleted file mode 100644
index ed0fb37..0000000
--- a/assignment1/.clang-format
+++ /dev/null
@@ -1,58 +0,0 @@
-# Generated from CLion C/C++ Code Style settings
----
-Language: Cpp
-BasedOnStyle: LLVM
-AccessModifierOffset: -4
-AlignConsecutiveAssignments: false
-AlignConsecutiveDeclarations: false
-AlignOperands: true
-AlignTrailingComments: false
-AlwaysBreakTemplateDeclarations: Yes
-BraceWrapping:
- AfterCaseLabel: false
- AfterClass: false
- AfterControlStatement: false
- AfterEnum: false
- AfterFunction: true
- AfterNamespace: true
- AfterStruct: false
- AfterUnion: false
- AfterExternBlock: false
- BeforeCatch: false
- BeforeElse: false
- BeforeLambdaBody: false
- BeforeWhile: false
- SplitEmptyFunction: true
- SplitEmptyRecord: true
- SplitEmptyNamespace: true
-BreakBeforeBraces: Custom
-BreakConstructorInitializers: AfterColon
-BreakConstructorInitializersBeforeComma: false
-ColumnLimit: 120
-ConstructorInitializerAllOnOneLineOrOnePerLine: false
-ContinuationIndentWidth: 8
-IncludeCategories:
- - Regex: '^<.*'
- Priority: 1
- - Regex: '^".*'
- Priority: 2
- - Regex: '.*'
- Priority: 3
-IncludeIsMainRegex: '([-_](test|unittest))?$'
-IndentCaseLabels: true
-IndentWidth: 4
-InsertNewlineAtEOF: true
-MacroBlockBegin: ''
-MacroBlockEnd: ''
-MaxEmptyLinesToKeep: 2
-NamespaceIndentation: All
-SpaceAfterCStyleCast: true
-SpaceAfterTemplateKeyword: false
-SpaceBeforeRangeBasedForLoopColon: false
-SpaceInEmptyParentheses: false
-SpacesInAngles: false
-SpacesInConditionalStatement: false
-SpacesInCStyleCastParentheses: false
-SpacesInParentheses: false
-TabWidth: 4
-...
diff --git a/assignment1/.idea/workspace.xml b/assignment1/.idea/workspace.xml
deleted file mode 100644
index 253a47c..0000000
--- a/assignment1/.idea/workspace.xml
+++ /dev/null
@@ -1,143 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
- {
- "useNewFormat": true
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- {
- "associatedIndex": 0
-}
-
-
-
-
-
- {
- "keyToString": {
- "ModuleVcsDetector.initialDetectionPerformed": "true",
- "RunOnceActivity.RadMigrateCodeStyle": "true",
- "RunOnceActivity.ShowReadmeOnStart": "true",
- "RunOnceActivity.cidr.known.project.marker": "true",
- "RunOnceActivity.git.unshallow": "true",
- "RunOnceActivity.readMode.enableVisualFormatting": "true",
- "RunOnceActivity.west.config.association.type.startup.service": "true",
- "cf.advertisement.text.overridden": "true",
- "cf.first.check.clang-format": "false",
- "cidr.known.project.marker": "true",
- "git-widget-placeholder": "main",
- "ignore.virus.scanning.warn.message": "true",
- "junie.onboarding.icon.badge.shown": "true",
- "node.js.detected.package.eslint": "true",
- "node.js.detected.package.tslint": "true",
- "node.js.selected.package.eslint": "(autodetect)",
- "node.js.selected.package.tslint": "(autodetect)",
- "nodejs_package_manager_path": "npm",
- "settings.editor.selected.configurable": "preferences.sourceCode.C++",
- "to.speed.mode.migration.done": "true",
- "vue.rearranger.settings.migration": "true"
- }
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 1760370577663
-
-
- 1760370577663
-
-
-
-
-
-
-
-
-
- 1761229247141
-
-
-
- 1761229247141
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/assignment1/CMakeLists.txt b/assignment1/CMakeLists.txt
deleted file mode 100644
index 90ee4f4..0000000
--- a/assignment1/CMakeLists.txt
+++ /dev/null
@@ -1,12 +0,0 @@
-cmake_minimum_required(VERSION 4.0)
-project(assignment1)
-
-set(CMAKE_CXX_STANDARD 20)
-
-add_executable(assignment1 main.cpp
- TMovie.h
- TMovie.cpp
- TMovieList.cpp
- TMovieList.h
- TMovieNode.cpp
- TMovieNode.h)
diff --git a/assignment1/TMovie.cpp b/assignment1/TMovie.cpp
deleted file mode 100644
index a92d8dc..0000000
--- a/assignment1/TMovie.cpp
+++ /dev/null
@@ -1,5 +0,0 @@
-//
-// Created by csand on 13/10/2025.
-//
-
-#include "TMovie.h"
diff --git a/assignment1/TMovie.h b/assignment1/TMovie.h
deleted file mode 100644
index c830548..0000000
--- a/assignment1/TMovie.h
+++ /dev/null
@@ -1,59 +0,0 @@
-
-
-#ifndef IKT203_TMOVIE_H
-#define IKT203_TMOVIE_H
-#include
-#include
-
-enum EMovieGenreType{
- ACTION = 1 << 0,
- COMEDY = 1<< 1,
- SCIFI = 1 << 2,
- HORROR = 1 << 3,
- DRAMA = 1 << 4
-};
-
-
-class TMovie
- {
- private:
- std::string title;
- std::string director;
- int year;
- EMovieGenreType genre;
- float score;
-
- public:
-
- TMovie(std::string T, std::string D, int Y, EMovieGenreType G, float S) :
- title(std::move(T)), director(std::move(D)), year(Y), genre(G), score(S) {}
-
- // Simple getters - using [[nodiscard]] to give warning if value is not used
- [[nodiscard]] std::string GetTitle() const
- {
- return title;
- }
- [[nodiscard]] std::string GetDirector() const
- {
- return director;
- }
- [[nodiscard]] int GetYear() const
- {
- return year;
- }
- [[nodiscard]] EMovieGenreType GetGenre() const
- {
- return genre;
- }
- [[nodiscard]] float GetScore() const
- {
- return score;
- }
-
- // Not declaring a destructor since the default compiler destructor is
-
-
-};
-
-
-#endif //IKT203_TMOVIE_H
diff --git a/assignment1/TMovieList.cpp b/assignment1/TMovieList.cpp
deleted file mode 100644
index 4336c57..0000000
--- a/assignment1/TMovieList.cpp
+++ /dev/null
@@ -1,95 +0,0 @@
-#include "TMovieList.h"
-
-#include
-
-using namespace std;
-
-void TMovieList::Append(TMovie* m)
-{
- // Time complexity O(1) with using tail and prev nodes
- auto* newNode = new TMovieNode(m);
- newNode->SetPrevNode(tail);
- tail->SetNextNode(newNode);
- tail = newNode;
- cout << "Appended '" << m->GetTitle() << "' into existing list of movies" <GetNextNode();
- newNode->SetNextNode(head->GetNextNode());
- head->SetNextNode(newNode);
-
- newNode->SetPrevNode(head);
- if (old)
- old->SetPrevNode(newNode);
-
- cout << "Prepended '" << m->GetTitle() << "' into list of movies" < ugyldig
- if (index < 0)
- return nullptr;
-
- auto* node = head->GetNextNode();
- int i = 0;
- while (node != nullptr && i < index)
- {
- node = node->GetNextNode();
- i++;
- }
-
- // Index stÞrre enn lista -> ugyldig
- if (node == nullptr)
- return nullptr;
- return node;
-
-}
-
-TMovie* TMovieList::GetAtIndex(const int index) const
-{
- auto* node = NavigateToNode(index);
- return node ? node->GetMovie() : nullptr;
-}
-
-void TMovieList::Remove(const int index)
-{
- auto* node = NavigateToNode(index);
- if (node == nullptr)
- return;
-
- auto* prev = node->GetPrevNode();
- auto* next = node->GetNextNode();
-
- if (prev)
- prev->SetNextNode(next);
- if (next)
- next->SetPrevNode(prev);
- else
- tail = (prev ? prev : head);
-
-
- if (head->GetNextNode() == nullptr)
- tail = head;
-
- delete node;
-}
-
-TMovie *TMovieList::SearchFor(const FCheckMovie check_movie, void *criteria) const
-{
- auto* node = head->GetNextNode();
- while (node != nullptr)
- {
- if (check_movie(node->GetMovie(), criteria))
- {
- return node->GetMovie();
- }
- node = node->GetNextNode();
- }
- return nullptr;
-}
diff --git a/assignment1/TMovieList.h b/assignment1/TMovieList.h
deleted file mode 100644
index 6d9e02a..0000000
--- a/assignment1/TMovieList.h
+++ /dev/null
@@ -1,41 +0,0 @@
-#ifndef IKT203_TMOVIELIST_H
-#define IKT203_TMOVIELIST_H
-
-#include "TMovie.h"
-#include "TMovieNode.h"
-
-// typedef to increase flexibility and reduce code recycling
-typedef bool (*FCheckMovie)(TMovie* movie, void* criteria);
-
-class TMovieList {
-private:
- TMovieNode* head;
- TMovieNode* tail;
-
-public:
- TMovieList() : head(new TMovieNode(nullptr)), tail(head) {}
-
- ~TMovieList()
- {
- TMovieNode* current = head;
- while(current)
- {
- TMovieNode* next = current->GetNextNode();
- delete current;
- current = next;
- }
- head = nullptr;
- tail = nullptr;
- }
- void Append(TMovie* m);
- void Prepend(TMovie* m);
- TMovie* SearchFor(FCheckMovie check_movie, void* criteria) const;
-
- [[nodiscard]] TMovieNode *NavigateToNode(int index) const;
-
- [[nodiscard]] TMovie* GetAtIndex(int index) const;
- void Remove(int index);
-};
-
-
-#endif //IKT203_TMOVIELIST_H
diff --git a/assignment1/TMovieNode.cpp b/assignment1/TMovieNode.cpp
deleted file mode 100644
index c63315d..0000000
--- a/assignment1/TMovieNode.cpp
+++ /dev/null
@@ -1,6 +0,0 @@
-//
-// Created by csand on 13/10/2025.
-//
-
-#include "TMovieNode.h"
-
diff --git a/assignment1/TMovieNode.h b/assignment1/TMovieNode.h
deleted file mode 100644
index 13cc3c7..0000000
--- a/assignment1/TMovieNode.h
+++ /dev/null
@@ -1,52 +0,0 @@
-#ifndef IKT203_TMOVIENODE_H
-#define IKT203_TMOVIENODE_H
-
-#include "TMovie.h"
-
-class TMovieNode {
-private:
-
- TMovie* movie;
- TMovieNode* nextNode;
- TMovieNode* prevNode;
-
-public:
-
- // constructor
- explicit TMovieNode(TMovie* moviePointer) : movie(moviePointer), nextNode(nullptr), prevNode(nullptr) {}
-
- // destructor
- ~TMovieNode()
- {
- delete movie;
- movie = nullptr;
- }
-
- // getters and setters for next and previous nodes
- [[nodiscard]] TMovieNode* GetNextNode() const
- {
- return nextNode;
- }
-
- void SetNextNode(TMovieNode* next)
- {
- nextNode = next;
- }
-
- [[nodiscard]] TMovieNode* GetPrevNode() const
- {
- return prevNode;
- }
- void SetPrevNode(TMovieNode* prev)
- {
- prevNode = prev;
- }
- [[nodiscard]] TMovie* GetMovie() const
- {
- return movie;
- }
-};
-
-
-
-#endif //IKT203_TMOVIENODE_H
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/query/cache-v2 b/assignment1/cmake-build-debug/.cmake/api/v1/query/cache-v2
deleted file mode 100644
index e69de29..0000000
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/query/cmakeFiles-v1 b/assignment1/cmake-build-debug/.cmake/api/v1/query/cmakeFiles-v1
deleted file mode 100644
index e69de29..0000000
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/query/codemodel-v2 b/assignment1/cmake-build-debug/.cmake/api/v1/query/codemodel-v2
deleted file mode 100644
index e69de29..0000000
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/query/toolchains-v1 b/assignment1/cmake-build-debug/.cmake/api/v1/query/toolchains-v1
deleted file mode 100644
index e69de29..0000000
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/cache-v2-156341a28a522a650372.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/cache-v2-156341a28a522a650372.json
deleted file mode 100644
index d03822f..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/cache-v2-156341a28a522a650372.json
+++ /dev/null
@@ -1,1343 +0,0 @@
-{
- "entries" :
- [
- {
- "name" : "CMAKE_ADDR2LINE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/addr2line.exe"
- },
- {
- "name" : "CMAKE_AR",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe"
- },
- {
- "name" : "CMAKE_BUILD_TYPE",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Choose the type of build, options are: None Debug Release RelWithDebInfo MinSizeRel ..."
- }
- ],
- "type" : "STRING",
- "value" : "Debug"
- },
- {
- "name" : "CMAKE_CACHEFILE_DIR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "This is the directory where this CMakeCache.txt was created"
- }
- ],
- "type" : "INTERNAL",
- "value" : "c:/Users/csand/IKT203/assignment1/cmake-build-debug"
- },
- {
- "name" : "CMAKE_CACHE_MAJOR_VERSION",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Major version of cmake used to create the current loaded cache"
- }
- ],
- "type" : "INTERNAL",
- "value" : "4"
- },
- {
- "name" : "CMAKE_CACHE_MINOR_VERSION",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Minor version of cmake used to create the current loaded cache"
- }
- ],
- "type" : "INTERNAL",
- "value" : "0"
- },
- {
- "name" : "CMAKE_CACHE_PATCH_VERSION",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Patch version of cmake used to create the current loaded cache"
- }
- ],
- "type" : "INTERNAL",
- "value" : "2"
- },
- {
- "name" : "CMAKE_COLOR_DIAGNOSTICS",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Enable colored diagnostics throughout."
- }
- ],
- "type" : "BOOL",
- "value" : "ON"
- },
- {
- "name" : "CMAKE_COMMAND",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Path to CMake executable."
- }
- ],
- "type" : "INTERNAL",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cmake.exe"
- },
- {
- "name" : "CMAKE_CPACK_COMMAND",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Path to cpack program executable."
- }
- ],
- "type" : "INTERNAL",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cpack.exe"
- },
- {
- "name" : "CMAKE_CTEST_COMMAND",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Path to ctest program executable."
- }
- ],
- "type" : "INTERNAL",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/ctest.exe"
- },
- {
- "name" : "CMAKE_CXX_COMPILER",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "CXX compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe"
- },
- {
- "name" : "CMAKE_CXX_COMPILER_AR",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "A wrapper around 'ar' adding the appropriate '--plugin' option for the GCC compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe"
- },
- {
- "name" : "CMAKE_CXX_COMPILER_RANLIB",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "A wrapper around 'ranlib' adding the appropriate '--plugin' option for the GCC compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe"
- },
- {
- "name" : "CMAKE_CXX_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the CXX compiler during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_CXX_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the CXX compiler during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : "-g"
- },
- {
- "name" : "CMAKE_CXX_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the CXX compiler during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : "-Os -DNDEBUG"
- },
- {
- "name" : "CMAKE_CXX_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the CXX compiler during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : "-O3 -DNDEBUG"
- },
- {
- "name" : "CMAKE_CXX_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the CXX compiler during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : "-O2 -g -DNDEBUG"
- },
- {
- "name" : "CMAKE_CXX_STANDARD_LIBRARIES",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Libraries linked by default with all C++ applications."
- }
- ],
- "type" : "STRING",
- "value" : "-lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32"
- },
- {
- "name" : "CMAKE_C_COMPILER",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "C compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe"
- },
- {
- "name" : "CMAKE_C_COMPILER_AR",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "A wrapper around 'ar' adding the appropriate '--plugin' option for the GCC compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe"
- },
- {
- "name" : "CMAKE_C_COMPILER_RANLIB",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "A wrapper around 'ranlib' adding the appropriate '--plugin' option for the GCC compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe"
- },
- {
- "name" : "CMAKE_C_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the C compiler during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_C_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the C compiler during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : "-g"
- },
- {
- "name" : "CMAKE_C_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the C compiler during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : "-Os -DNDEBUG"
- },
- {
- "name" : "CMAKE_C_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the C compiler during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : "-O3 -DNDEBUG"
- },
- {
- "name" : "CMAKE_C_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the C compiler during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : "-O2 -g -DNDEBUG"
- },
- {
- "name" : "CMAKE_C_STANDARD_LIBRARIES",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Libraries linked by default with all C applications."
- }
- ],
- "type" : "STRING",
- "value" : "-lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32"
- },
- {
- "name" : "CMAKE_DLLTOOL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/dlltool.exe"
- },
- {
- "name" : "CMAKE_EXECUTABLE_FORMAT",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Executable file format"
- }
- ],
- "type" : "INTERNAL",
- "value" : "Unknown"
- },
- {
- "name" : "CMAKE_EXE_LINKER_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXE_LINKER_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXE_LINKER_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXE_LINKER_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXPORT_BUILD_DATABASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Enable/Disable output of build database during the build."
- }
- ],
- "type" : "BOOL",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXPORT_COMPILE_COMMANDS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Enable/Disable output of compile commands during generation."
- }
- ],
- "type" : "BOOL",
- "value" : ""
- },
- {
- "name" : "CMAKE_EXTRA_GENERATOR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Name of external makefile project generator."
- }
- ],
- "type" : "INTERNAL",
- "value" : ""
- },
- {
- "name" : "CMAKE_FIND_PACKAGE_REDIRECTS_DIR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake."
- }
- ],
- "type" : "STATIC",
- "value" : "C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/pkgRedirects"
- },
- {
- "name" : "CMAKE_GENERATOR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Name of generator."
- }
- ],
- "type" : "INTERNAL",
- "value" : "Ninja"
- },
- {
- "name" : "CMAKE_GENERATOR_INSTANCE",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Generator instance identifier."
- }
- ],
- "type" : "INTERNAL",
- "value" : ""
- },
- {
- "name" : "CMAKE_GENERATOR_PLATFORM",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Name of generator platform."
- }
- ],
- "type" : "INTERNAL",
- "value" : ""
- },
- {
- "name" : "CMAKE_GENERATOR_TOOLSET",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Name of generator toolset."
- }
- ],
- "type" : "INTERNAL",
- "value" : ""
- },
- {
- "name" : "CMAKE_GNUtoMS",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Convert GNU import libraries to MS format (requires Visual Studio)"
- }
- ],
- "type" : "BOOL",
- "value" : "OFF"
- },
- {
- "name" : "CMAKE_HOME_DIRECTORY",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Source directory with the top level CMakeLists.txt file for this project"
- }
- ],
- "type" : "INTERNAL",
- "value" : "C:/Users/csand/IKT203/assignment1"
- },
- {
- "name" : "CMAKE_INSTALL_PREFIX",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Install path prefix, prepended onto install directories."
- }
- ],
- "type" : "PATH",
- "value" : "C:/Program Files (x86)/assignment1"
- },
- {
- "name" : "CMAKE_LINKER",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe"
- },
- {
- "name" : "CMAKE_LIST_FILE_NAME",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Name of CMakeLists files to read"
- }
- ],
- "type" : "INTERNAL",
- "value" : "CMakeLists.txt"
- },
- {
- "name" : "CMAKE_MAKE_PROGRAM",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "No help, variable specified on the command line."
- }
- ],
- "type" : "UNINITIALIZED",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe"
- },
- {
- "name" : "CMAKE_MODULE_LINKER_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of modules during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_MODULE_LINKER_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of modules during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of modules during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_MODULE_LINKER_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of modules during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of modules during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_NM",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/nm.exe"
- },
- {
- "name" : "CMAKE_NUMBER_OF_MAKEFILES",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "number of local generators"
- }
- ],
- "type" : "INTERNAL",
- "value" : "1"
- },
- {
- "name" : "CMAKE_OBJCOPY",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/objcopy.exe"
- },
- {
- "name" : "CMAKE_OBJDUMP",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/objdump.exe"
- },
- {
- "name" : "CMAKE_PLATFORM_INFO_INITIALIZED",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Platform information initialized"
- }
- ],
- "type" : "INTERNAL",
- "value" : "1"
- },
- {
- "name" : "CMAKE_PROJECT_DESCRIPTION",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : ""
- },
- {
- "name" : "CMAKE_PROJECT_HOMEPAGE_URL",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : ""
- },
- {
- "name" : "CMAKE_PROJECT_NAME",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : "assignment1"
- },
- {
- "name" : "CMAKE_RANLIB",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe"
- },
- {
- "name" : "CMAKE_RC_COMPILER",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "RC compiler"
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/windres.exe"
- },
- {
- "name" : "CMAKE_RC_COMPILER_WORKS",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : ""
- }
- ],
- "type" : "INTERNAL",
- "value" : "1"
- },
- {
- "name" : "CMAKE_RC_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags for Windows Resource Compiler during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_RC_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags for Windows Resource Compiler during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_RC_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags for Windows Resource Compiler during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_RC_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags for Windows Resource Compiler during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_RC_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags for Windows Resource Compiler during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_READELF",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/readelf.exe"
- },
- {
- "name" : "CMAKE_ROOT",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Path to CMake installation."
- }
- ],
- "type" : "INTERNAL",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0"
- },
- {
- "name" : "CMAKE_SHARED_LINKER_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of shared libraries during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_SHARED_LINKER_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of shared libraries during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of shared libraries during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_SHARED_LINKER_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of shared libraries during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of shared libraries during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_SKIP_INSTALL_RPATH",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "If set, runtime paths are not added when installing shared libraries, but are added when building."
- }
- ],
- "type" : "BOOL",
- "value" : "NO"
- },
- {
- "name" : "CMAKE_SKIP_RPATH",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "If set, runtime paths are not added when using shared libraries."
- }
- ],
- "type" : "BOOL",
- "value" : "NO"
- },
- {
- "name" : "CMAKE_STATIC_LINKER_FLAGS",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of static libraries during all build types."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_STATIC_LINKER_FLAGS_DEBUG",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of static libraries during DEBUG builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of static libraries during MINSIZEREL builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_STATIC_LINKER_FLAGS_RELEASE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of static libraries during RELEASE builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Flags used by the linker during the creation of static libraries during RELWITHDEBINFO builds."
- }
- ],
- "type" : "STRING",
- "value" : ""
- },
- {
- "name" : "CMAKE_STRIP",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/strip.exe"
- },
- {
- "name" : "CMAKE_TAPI",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "Path to a program."
- }
- ],
- "type" : "FILEPATH",
- "value" : "CMAKE_TAPI-NOTFOUND"
- },
- {
- "name" : "CMAKE_VERBOSE_MAKEFILE",
- "properties" :
- [
- {
- "name" : "ADVANCED",
- "value" : "1"
- },
- {
- "name" : "HELPSTRING",
- "value" : "If this value is on, makefiles will be generated without the .SILENT directive, and all commands will be echoed to the console during the make. This is useful for debugging only. With Visual Studio IDE projects all commands are done without /nologo."
- }
- ],
- "type" : "BOOL",
- "value" : "FALSE"
- },
- {
- "name" : "assignment1_BINARY_DIR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : "C:/Users/csand/IKT203/assignment1/cmake-build-debug"
- },
- {
- "name" : "assignment1_IS_TOP_LEVEL",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : "ON"
- },
- {
- "name" : "assignment1_SOURCE_DIR",
- "properties" :
- [
- {
- "name" : "HELPSTRING",
- "value" : "Value Computed by CMake"
- }
- ],
- "type" : "STATIC",
- "value" : "C:/Users/csand/IKT203/assignment1"
- }
- ],
- "kind" : "cache",
- "version" :
- {
- "major" : 2,
- "minor" : 0
- }
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/cmakeFiles-v1-fe79851469594e5c9889.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/cmakeFiles-v1-fe79851469594e5c9889.json
deleted file mode 100644
index c357c78..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/cmakeFiles-v1-fe79851469594e5c9889.json
+++ /dev/null
@@ -1,230 +0,0 @@
-{
- "inputs" :
- [
- {
- "path" : "CMakeLists.txt"
- },
- {
- "isGenerated" : true,
- "path" : "cmake-build-debug/CMakeFiles/4.0.2/CMakeSystem.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInitialize.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-Initialize.cmake"
- },
- {
- "isGenerated" : true,
- "path" : "cmake-build-debug/CMakeFiles/4.0.2/CMakeCCompiler.cmake"
- },
- {
- "isGenerated" : true,
- "path" : "cmake-build-debug/CMakeFiles/4.0.2/CMakeCXXCompiler.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeGenericSystem.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeInitializeConfigs.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/WindowsPaths.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeLanguageInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-C.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/CMakeCommonCompilerMacros.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU.cmake"
- },
- {
- "isGenerated" : true,
- "path" : "cmake-build-debug/CMakeFiles/4.0.2/CMakeRCCompiler.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeRCInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-windres.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C-ABI.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCommonLanguageInclude.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCLinkerInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCommonLinkerInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-C.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-C.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeLanguageInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-CXX.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX-ABI.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCommonLanguageInclude.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCXXLinkerInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCommonLinkerInformation.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-CXX.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-CXX.cmake"
- },
- {
- "isCMake" : true,
- "isExternal" : true,
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU.cmake"
- }
- ],
- "kind" : "cmakeFiles",
- "paths" :
- {
- "build" : "C:/Users/csand/IKT203/assignment1/cmake-build-debug",
- "source" : "C:/Users/csand/IKT203/assignment1"
- },
- "version" :
- {
- "major" : 1,
- "minor" : 1
- }
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/codemodel-v2-0df2d11af4c1b42d73f2.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/codemodel-v2-0df2d11af4c1b42d73f2.json
deleted file mode 100644
index 4806874..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/codemodel-v2-0df2d11af4c1b42d73f2.json
+++ /dev/null
@@ -1,60 +0,0 @@
-{
- "configurations" :
- [
- {
- "directories" :
- [
- {
- "build" : ".",
- "jsonFile" : "directory-.-Debug-d0094a50bb2071803777.json",
- "minimumCMakeVersion" :
- {
- "string" : "4.0"
- },
- "projectIndex" : 0,
- "source" : ".",
- "targetIndexes" :
- [
- 0
- ]
- }
- ],
- "name" : "Debug",
- "projects" :
- [
- {
- "directoryIndexes" :
- [
- 0
- ],
- "name" : "assignment1",
- "targetIndexes" :
- [
- 0
- ]
- }
- ],
- "targets" :
- [
- {
- "directoryIndex" : 0,
- "id" : "assignment1::@6890427a1f51a3e7e1df",
- "jsonFile" : "target-assignment1-Debug-46d5c067e4441b13457a.json",
- "name" : "assignment1",
- "projectIndex" : 0
- }
- ]
- }
- ],
- "kind" : "codemodel",
- "paths" :
- {
- "build" : "C:/Users/csand/IKT203/assignment1/cmake-build-debug",
- "source" : "C:/Users/csand/IKT203/assignment1"
- },
- "version" :
- {
- "major" : 2,
- "minor" : 8
- }
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/directory-.-Debug-d0094a50bb2071803777.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/directory-.-Debug-d0094a50bb2071803777.json
deleted file mode 100644
index 3a67af9..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/directory-.-Debug-d0094a50bb2071803777.json
+++ /dev/null
@@ -1,14 +0,0 @@
-{
- "backtraceGraph" :
- {
- "commands" : [],
- "files" : [],
- "nodes" : []
- },
- "installers" : [],
- "paths" :
- {
- "build" : ".",
- "source" : "."
- }
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/index-2025-10-23T14-37-49-0450.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/index-2025-10-23T14-37-49-0450.json
deleted file mode 100644
index 2a7fe62..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/index-2025-10-23T14-37-49-0450.json
+++ /dev/null
@@ -1,108 +0,0 @@
-{
- "cmake" :
- {
- "generator" :
- {
- "multiConfig" : false,
- "name" : "Ninja"
- },
- "paths" :
- {
- "cmake" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cmake.exe",
- "cpack" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cpack.exe",
- "ctest" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/ctest.exe",
- "root" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0"
- },
- "version" :
- {
- "isDirty" : false,
- "major" : 4,
- "minor" : 0,
- "patch" : 2,
- "string" : "4.0.2",
- "suffix" : ""
- }
- },
- "objects" :
- [
- {
- "jsonFile" : "codemodel-v2-0df2d11af4c1b42d73f2.json",
- "kind" : "codemodel",
- "version" :
- {
- "major" : 2,
- "minor" : 8
- }
- },
- {
- "jsonFile" : "cache-v2-156341a28a522a650372.json",
- "kind" : "cache",
- "version" :
- {
- "major" : 2,
- "minor" : 0
- }
- },
- {
- "jsonFile" : "cmakeFiles-v1-fe79851469594e5c9889.json",
- "kind" : "cmakeFiles",
- "version" :
- {
- "major" : 1,
- "minor" : 1
- }
- },
- {
- "jsonFile" : "toolchains-v1-f99d97189c24f24b8266.json",
- "kind" : "toolchains",
- "version" :
- {
- "major" : 1,
- "minor" : 0
- }
- }
- ],
- "reply" :
- {
- "cache-v2" :
- {
- "jsonFile" : "cache-v2-156341a28a522a650372.json",
- "kind" : "cache",
- "version" :
- {
- "major" : 2,
- "minor" : 0
- }
- },
- "cmakeFiles-v1" :
- {
- "jsonFile" : "cmakeFiles-v1-fe79851469594e5c9889.json",
- "kind" : "cmakeFiles",
- "version" :
- {
- "major" : 1,
- "minor" : 1
- }
- },
- "codemodel-v2" :
- {
- "jsonFile" : "codemodel-v2-0df2d11af4c1b42d73f2.json",
- "kind" : "codemodel",
- "version" :
- {
- "major" : 2,
- "minor" : 8
- }
- },
- "toolchains-v1" :
- {
- "jsonFile" : "toolchains-v1-f99d97189c24f24b8266.json",
- "kind" : "toolchains",
- "version" :
- {
- "major" : 1,
- "minor" : 0
- }
- }
- }
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/target-assignment1-Debug-46d5c067e4441b13457a.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/target-assignment1-Debug-46d5c067e4441b13457a.json
deleted file mode 100644
index 5d00dcb..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/target-assignment1-Debug-46d5c067e4441b13457a.json
+++ /dev/null
@@ -1,150 +0,0 @@
-{
- "artifacts" :
- [
- {
- "path" : "assignment1.exe"
- },
- {
- "path" : "assignment1.pdb"
- }
- ],
- "backtrace" : 1,
- "backtraceGraph" :
- {
- "commands" :
- [
- "add_executable"
- ],
- "files" :
- [
- "CMakeLists.txt"
- ],
- "nodes" :
- [
- {
- "file" : 0
- },
- {
- "command" : 0,
- "file" : 0,
- "line" : 6,
- "parent" : 0
- }
- ]
- },
- "compileGroups" :
- [
- {
- "compileCommandFragments" :
- [
- {
- "fragment" : "-g -std=gnu++20 -fdiagnostics-color=always"
- }
- ],
- "language" : "CXX",
- "languageStandard" :
- {
- "backtraces" :
- [
- 1
- ],
- "standard" : "20"
- },
- "sourceIndexes" :
- [
- 0,
- 2,
- 3,
- 5
- ]
- }
- ],
- "id" : "assignment1::@6890427a1f51a3e7e1df",
- "link" :
- {
- "commandFragments" :
- [
- {
- "fragment" : "-g",
- "role" : "flags"
- },
- {
- "fragment" : "-lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32",
- "role" : "libraries"
- }
- ],
- "language" : "CXX"
- },
- "name" : "assignment1",
- "nameOnDisk" : "assignment1.exe",
- "paths" :
- {
- "build" : ".",
- "source" : "."
- },
- "sourceGroups" :
- [
- {
- "name" : "Source Files",
- "sourceIndexes" :
- [
- 0,
- 2,
- 3,
- 5
- ]
- },
- {
- "name" : "Header Files",
- "sourceIndexes" :
- [
- 1,
- 4,
- 6
- ]
- }
- ],
- "sources" :
- [
- {
- "backtrace" : 1,
- "compileGroupIndex" : 0,
- "path" : "main.cpp",
- "sourceGroupIndex" : 0
- },
- {
- "backtrace" : 1,
- "path" : "TMovie.h",
- "sourceGroupIndex" : 1
- },
- {
- "backtrace" : 1,
- "compileGroupIndex" : 0,
- "path" : "TMovie.cpp",
- "sourceGroupIndex" : 0
- },
- {
- "backtrace" : 1,
- "compileGroupIndex" : 0,
- "path" : "TMovieList.cpp",
- "sourceGroupIndex" : 0
- },
- {
- "backtrace" : 1,
- "path" : "TMovieList.h",
- "sourceGroupIndex" : 1
- },
- {
- "backtrace" : 1,
- "compileGroupIndex" : 0,
- "path" : "TMovieNode.cpp",
- "sourceGroupIndex" : 0
- },
- {
- "backtrace" : 1,
- "path" : "TMovieNode.h",
- "sourceGroupIndex" : 1
- }
- ],
- "type" : "EXECUTABLE"
-}
diff --git a/assignment1/cmake-build-debug/.cmake/api/v1/reply/toolchains-v1-f99d97189c24f24b8266.json b/assignment1/cmake-build-debug/.cmake/api/v1/reply/toolchains-v1-f99d97189c24f24b8266.json
deleted file mode 100644
index 7e2dd96..0000000
--- a/assignment1/cmake-build-debug/.cmake/api/v1/reply/toolchains-v1-f99d97189c24f24b8266.json
+++ /dev/null
@@ -1,144 +0,0 @@
-{
- "kind" : "toolchains",
- "toolchains" :
- [
- {
- "compiler" :
- {
- "id" : "GNU",
- "implicit" :
- {
- "includeDirectories" :
- [
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include"
- ],
- "linkDirectories" :
- [
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib"
- ],
- "linkFrameworkDirectories" : [],
- "linkLibraries" :
- [
- "mingw32",
- "gcc",
- "moldname",
- "mingwex",
- "kernel32",
- "pthread",
- "advapi32",
- "shell32",
- "user32",
- "kernel32",
- "iconv",
- "mingw32",
- "gcc",
- "moldname",
- "mingwex",
- "kernel32"
- ]
- },
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe",
- "version" : "13.1.0"
- },
- "language" : "C",
- "sourceFileExtensions" :
- [
- "c",
- "m"
- ]
- },
- {
- "compiler" :
- {
- "id" : "GNU",
- "implicit" :
- {
- "includeDirectories" :
- [
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include"
- ],
- "linkDirectories" :
- [
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib",
- "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib"
- ],
- "linkFrameworkDirectories" : [],
- "linkLibraries" :
- [
- "stdc++",
- "mingw32",
- "gcc_s",
- "gcc",
- "moldname",
- "mingwex",
- "kernel32",
- "pthread",
- "advapi32",
- "shell32",
- "user32",
- "kernel32",
- "iconv",
- "mingw32",
- "gcc_s",
- "gcc",
- "moldname",
- "mingwex",
- "kernel32"
- ]
- },
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe",
- "version" : "13.1.0"
- },
- "language" : "CXX",
- "sourceFileExtensions" :
- [
- "C",
- "M",
- "c++",
- "cc",
- "cpp",
- "cxx",
- "mm",
- "mpp",
- "CPP",
- "ixx",
- "cppm",
- "ccm",
- "cxxm",
- "c++m"
- ]
- },
- {
- "compiler" :
- {
- "implicit" : {},
- "path" : "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/windres.exe"
- },
- "language" : "RC",
- "sourceFileExtensions" :
- [
- "rc",
- "RC"
- ]
- }
- ],
- "version" :
- {
- "major" : 1,
- "minor" : 0
- }
-}
diff --git a/assignment1/cmake-build-debug/CMakeCache.txt b/assignment1/cmake-build-debug/CMakeCache.txt
deleted file mode 100644
index e8b6f2d..0000000
--- a/assignment1/cmake-build-debug/CMakeCache.txt
+++ /dev/null
@@ -1,420 +0,0 @@
-# This is the CMakeCache file.
-# For build in directory: c:/Users/csand/IKT203/assignment1/cmake-build-debug
-# It was generated by CMake: C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cmake.exe
-# You can edit this file to change values found and used by cmake.
-# If you do not want to change any of the values, simply exit the editor.
-# If you do want to change a value, simply edit, save, and exit the editor.
-# The syntax for the file is as follows:
-# KEY:TYPE=VALUE
-# KEY is the name of a variable in the cache.
-# TYPE is a hint to GUIs for the type of VALUE, DO NOT EDIT TYPE!.
-# VALUE is the current value for the KEY.
-
-########################
-# EXTERNAL cache entries
-########################
-
-//Path to a program.
-CMAKE_ADDR2LINE:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/addr2line.exe
-
-//Path to a program.
-CMAKE_AR:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe
-
-//Choose the type of build, options are: None Debug Release RelWithDebInfo
-// MinSizeRel ...
-CMAKE_BUILD_TYPE:STRING=Debug
-
-//Enable colored diagnostics throughout.
-CMAKE_COLOR_DIAGNOSTICS:BOOL=ON
-
-//CXX compiler
-CMAKE_CXX_COMPILER:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe
-
-//A wrapper around 'ar' adding the appropriate '--plugin' option
-// for the GCC compiler
-CMAKE_CXX_COMPILER_AR:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe
-
-//A wrapper around 'ranlib' adding the appropriate '--plugin' option
-// for the GCC compiler
-CMAKE_CXX_COMPILER_RANLIB:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe
-
-//Flags used by the CXX compiler during all build types.
-CMAKE_CXX_FLAGS:STRING=
-
-//Flags used by the CXX compiler during DEBUG builds.
-CMAKE_CXX_FLAGS_DEBUG:STRING=-g
-
-//Flags used by the CXX compiler during MINSIZEREL builds.
-CMAKE_CXX_FLAGS_MINSIZEREL:STRING=-Os -DNDEBUG
-
-//Flags used by the CXX compiler during RELEASE builds.
-CMAKE_CXX_FLAGS_RELEASE:STRING=-O3 -DNDEBUG
-
-//Flags used by the CXX compiler during RELWITHDEBINFO builds.
-CMAKE_CXX_FLAGS_RELWITHDEBINFO:STRING=-O2 -g -DNDEBUG
-
-//Libraries linked by default with all C++ applications.
-CMAKE_CXX_STANDARD_LIBRARIES:STRING=-lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32
-
-//C compiler
-CMAKE_C_COMPILER:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe
-
-//A wrapper around 'ar' adding the appropriate '--plugin' option
-// for the GCC compiler
-CMAKE_C_COMPILER_AR:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe
-
-//A wrapper around 'ranlib' adding the appropriate '--plugin' option
-// for the GCC compiler
-CMAKE_C_COMPILER_RANLIB:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe
-
-//Flags used by the C compiler during all build types.
-CMAKE_C_FLAGS:STRING=
-
-//Flags used by the C compiler during DEBUG builds.
-CMAKE_C_FLAGS_DEBUG:STRING=-g
-
-//Flags used by the C compiler during MINSIZEREL builds.
-CMAKE_C_FLAGS_MINSIZEREL:STRING=-Os -DNDEBUG
-
-//Flags used by the C compiler during RELEASE builds.
-CMAKE_C_FLAGS_RELEASE:STRING=-O3 -DNDEBUG
-
-//Flags used by the C compiler during RELWITHDEBINFO builds.
-CMAKE_C_FLAGS_RELWITHDEBINFO:STRING=-O2 -g -DNDEBUG
-
-//Libraries linked by default with all C applications.
-CMAKE_C_STANDARD_LIBRARIES:STRING=-lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32
-
-//Path to a program.
-CMAKE_DLLTOOL:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/dlltool.exe
-
-//Flags used by the linker during all build types.
-CMAKE_EXE_LINKER_FLAGS:STRING=
-
-//Flags used by the linker during DEBUG builds.
-CMAKE_EXE_LINKER_FLAGS_DEBUG:STRING=
-
-//Flags used by the linker during MINSIZEREL builds.
-CMAKE_EXE_LINKER_FLAGS_MINSIZEREL:STRING=
-
-//Flags used by the linker during RELEASE builds.
-CMAKE_EXE_LINKER_FLAGS_RELEASE:STRING=
-
-//Flags used by the linker during RELWITHDEBINFO builds.
-CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO:STRING=
-
-//Enable/Disable output of build database during the build.
-CMAKE_EXPORT_BUILD_DATABASE:BOOL=
-
-//Enable/Disable output of compile commands during generation.
-CMAKE_EXPORT_COMPILE_COMMANDS:BOOL=
-
-//Value Computed by CMake.
-CMAKE_FIND_PACKAGE_REDIRECTS_DIR:STATIC=C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/pkgRedirects
-
-//Convert GNU import libraries to MS format (requires Visual Studio)
-CMAKE_GNUtoMS:BOOL=OFF
-
-//Install path prefix, prepended onto install directories.
-CMAKE_INSTALL_PREFIX:PATH=C:/Program Files (x86)/assignment1
-
-//Path to a program.
-CMAKE_LINKER:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe
-
-//No help, variable specified on the command line.
-CMAKE_MAKE_PROGRAM:UNINITIALIZED=C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe
-
-//Flags used by the linker during the creation of modules during
-// all build types.
-CMAKE_MODULE_LINKER_FLAGS:STRING=
-
-//Flags used by the linker during the creation of modules during
-// DEBUG builds.
-CMAKE_MODULE_LINKER_FLAGS_DEBUG:STRING=
-
-//Flags used by the linker during the creation of modules during
-// MINSIZEREL builds.
-CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL:STRING=
-
-//Flags used by the linker during the creation of modules during
-// RELEASE builds.
-CMAKE_MODULE_LINKER_FLAGS_RELEASE:STRING=
-
-//Flags used by the linker during the creation of modules during
-// RELWITHDEBINFO builds.
-CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO:STRING=
-
-//Path to a program.
-CMAKE_NM:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/nm.exe
-
-//Path to a program.
-CMAKE_OBJCOPY:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/objcopy.exe
-
-//Path to a program.
-CMAKE_OBJDUMP:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/objdump.exe
-
-//Value Computed by CMake
-CMAKE_PROJECT_DESCRIPTION:STATIC=
-
-//Value Computed by CMake
-CMAKE_PROJECT_HOMEPAGE_URL:STATIC=
-
-//Value Computed by CMake
-CMAKE_PROJECT_NAME:STATIC=assignment1
-
-//Path to a program.
-CMAKE_RANLIB:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe
-
-//RC compiler
-CMAKE_RC_COMPILER:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/windres.exe
-
-//Flags for Windows Resource Compiler during all build types.
-CMAKE_RC_FLAGS:STRING=
-
-//Flags for Windows Resource Compiler during DEBUG builds.
-CMAKE_RC_FLAGS_DEBUG:STRING=
-
-//Flags for Windows Resource Compiler during MINSIZEREL builds.
-CMAKE_RC_FLAGS_MINSIZEREL:STRING=
-
-//Flags for Windows Resource Compiler during RELEASE builds.
-CMAKE_RC_FLAGS_RELEASE:STRING=
-
-//Flags for Windows Resource Compiler during RELWITHDEBINFO builds.
-CMAKE_RC_FLAGS_RELWITHDEBINFO:STRING=
-
-//Path to a program.
-CMAKE_READELF:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/readelf.exe
-
-//Flags used by the linker during the creation of shared libraries
-// during all build types.
-CMAKE_SHARED_LINKER_FLAGS:STRING=
-
-//Flags used by the linker during the creation of shared libraries
-// during DEBUG builds.
-CMAKE_SHARED_LINKER_FLAGS_DEBUG:STRING=
-
-//Flags used by the linker during the creation of shared libraries
-// during MINSIZEREL builds.
-CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL:STRING=
-
-//Flags used by the linker during the creation of shared libraries
-// during RELEASE builds.
-CMAKE_SHARED_LINKER_FLAGS_RELEASE:STRING=
-
-//Flags used by the linker during the creation of shared libraries
-// during RELWITHDEBINFO builds.
-CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO:STRING=
-
-//If set, runtime paths are not added when installing shared libraries,
-// but are added when building.
-CMAKE_SKIP_INSTALL_RPATH:BOOL=NO
-
-//If set, runtime paths are not added when using shared libraries.
-CMAKE_SKIP_RPATH:BOOL=NO
-
-//Flags used by the linker during the creation of static libraries
-// during all build types.
-CMAKE_STATIC_LINKER_FLAGS:STRING=
-
-//Flags used by the linker during the creation of static libraries
-// during DEBUG builds.
-CMAKE_STATIC_LINKER_FLAGS_DEBUG:STRING=
-
-//Flags used by the linker during the creation of static libraries
-// during MINSIZEREL builds.
-CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL:STRING=
-
-//Flags used by the linker during the creation of static libraries
-// during RELEASE builds.
-CMAKE_STATIC_LINKER_FLAGS_RELEASE:STRING=
-
-//Flags used by the linker during the creation of static libraries
-// during RELWITHDEBINFO builds.
-CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO:STRING=
-
-//Path to a program.
-CMAKE_STRIP:FILEPATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/strip.exe
-
-//Path to a program.
-CMAKE_TAPI:FILEPATH=CMAKE_TAPI-NOTFOUND
-
-//If this value is on, makefiles will be generated without the
-// .SILENT directive, and all commands will be echoed to the console
-// during the make. This is useful for debugging only. With Visual
-// Studio IDE projects all commands are done without /nologo.
-CMAKE_VERBOSE_MAKEFILE:BOOL=FALSE
-
-//Value Computed by CMake
-assignment1_BINARY_DIR:STATIC=C:/Users/csand/IKT203/assignment1/cmake-build-debug
-
-//Value Computed by CMake
-assignment1_IS_TOP_LEVEL:STATIC=ON
-
-//Value Computed by CMake
-assignment1_SOURCE_DIR:STATIC=C:/Users/csand/IKT203/assignment1
-
-
-########################
-# INTERNAL cache entries
-########################
-
-//ADVANCED property for variable: CMAKE_ADDR2LINE
-CMAKE_ADDR2LINE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_AR
-CMAKE_AR-ADVANCED:INTERNAL=1
-//This is the directory where this CMakeCache.txt was created
-CMAKE_CACHEFILE_DIR:INTERNAL=c:/Users/csand/IKT203/assignment1/cmake-build-debug
-//Major version of cmake used to create the current loaded cache
-CMAKE_CACHE_MAJOR_VERSION:INTERNAL=4
-//Minor version of cmake used to create the current loaded cache
-CMAKE_CACHE_MINOR_VERSION:INTERNAL=0
-//Patch version of cmake used to create the current loaded cache
-CMAKE_CACHE_PATCH_VERSION:INTERNAL=2
-//Path to CMake executable.
-CMAKE_COMMAND:INTERNAL=C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cmake.exe
-//Path to cpack program executable.
-CMAKE_CPACK_COMMAND:INTERNAL=C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/cpack.exe
-//Path to ctest program executable.
-CMAKE_CTEST_COMMAND:INTERNAL=C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/bin/ctest.exe
-//ADVANCED property for variable: CMAKE_CXX_COMPILER
-CMAKE_CXX_COMPILER-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_COMPILER_AR
-CMAKE_CXX_COMPILER_AR-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_COMPILER_RANLIB
-CMAKE_CXX_COMPILER_RANLIB-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_FLAGS
-CMAKE_CXX_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_FLAGS_DEBUG
-CMAKE_CXX_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_FLAGS_MINSIZEREL
-CMAKE_CXX_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_FLAGS_RELEASE
-CMAKE_CXX_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_FLAGS_RELWITHDEBINFO
-CMAKE_CXX_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_CXX_STANDARD_LIBRARIES
-CMAKE_CXX_STANDARD_LIBRARIES-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_COMPILER
-CMAKE_C_COMPILER-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_COMPILER_AR
-CMAKE_C_COMPILER_AR-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_COMPILER_RANLIB
-CMAKE_C_COMPILER_RANLIB-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_FLAGS
-CMAKE_C_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_FLAGS_DEBUG
-CMAKE_C_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_FLAGS_MINSIZEREL
-CMAKE_C_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_FLAGS_RELEASE
-CMAKE_C_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_FLAGS_RELWITHDEBINFO
-CMAKE_C_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_C_STANDARD_LIBRARIES
-CMAKE_C_STANDARD_LIBRARIES-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_DLLTOOL
-CMAKE_DLLTOOL-ADVANCED:INTERNAL=1
-//Executable file format
-CMAKE_EXECUTABLE_FORMAT:INTERNAL=Unknown
-//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS
-CMAKE_EXE_LINKER_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_DEBUG
-CMAKE_EXE_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_MINSIZEREL
-CMAKE_EXE_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_RELEASE
-CMAKE_EXE_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO
-CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXPORT_BUILD_DATABASE
-CMAKE_EXPORT_BUILD_DATABASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_EXPORT_COMPILE_COMMANDS
-CMAKE_EXPORT_COMPILE_COMMANDS-ADVANCED:INTERNAL=1
-//Name of external makefile project generator.
-CMAKE_EXTRA_GENERATOR:INTERNAL=
-//Name of generator.
-CMAKE_GENERATOR:INTERNAL=Ninja
-//Generator instance identifier.
-CMAKE_GENERATOR_INSTANCE:INTERNAL=
-//Name of generator platform.
-CMAKE_GENERATOR_PLATFORM:INTERNAL=
-//Name of generator toolset.
-CMAKE_GENERATOR_TOOLSET:INTERNAL=
-//Source directory with the top level CMakeLists.txt file for this
-// project
-CMAKE_HOME_DIRECTORY:INTERNAL=C:/Users/csand/IKT203/assignment1
-//ADVANCED property for variable: CMAKE_LINKER
-CMAKE_LINKER-ADVANCED:INTERNAL=1
-//Name of CMakeLists files to read
-CMAKE_LIST_FILE_NAME:INTERNAL=CMakeLists.txt
-//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS
-CMAKE_MODULE_LINKER_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_DEBUG
-CMAKE_MODULE_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL
-CMAKE_MODULE_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_RELEASE
-CMAKE_MODULE_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO
-CMAKE_MODULE_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_NM
-CMAKE_NM-ADVANCED:INTERNAL=1
-//number of local generators
-CMAKE_NUMBER_OF_MAKEFILES:INTERNAL=1
-//ADVANCED property for variable: CMAKE_OBJCOPY
-CMAKE_OBJCOPY-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_OBJDUMP
-CMAKE_OBJDUMP-ADVANCED:INTERNAL=1
-//Platform information initialized
-CMAKE_PLATFORM_INFO_INITIALIZED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RANLIB
-CMAKE_RANLIB-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_COMPILER
-CMAKE_RC_COMPILER-ADVANCED:INTERNAL=1
-CMAKE_RC_COMPILER_WORKS:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_FLAGS
-CMAKE_RC_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_FLAGS_DEBUG
-CMAKE_RC_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_FLAGS_MINSIZEREL
-CMAKE_RC_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_FLAGS_RELEASE
-CMAKE_RC_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_RC_FLAGS_RELWITHDEBINFO
-CMAKE_RC_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_READELF
-CMAKE_READELF-ADVANCED:INTERNAL=1
-//Path to CMake installation.
-CMAKE_ROOT:INTERNAL=C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0
-//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS
-CMAKE_SHARED_LINKER_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_DEBUG
-CMAKE_SHARED_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL
-CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_RELEASE
-CMAKE_SHARED_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO
-CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SKIP_INSTALL_RPATH
-CMAKE_SKIP_INSTALL_RPATH-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_SKIP_RPATH
-CMAKE_SKIP_RPATH-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS
-CMAKE_STATIC_LINKER_FLAGS-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_DEBUG
-CMAKE_STATIC_LINKER_FLAGS_DEBUG-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL
-CMAKE_STATIC_LINKER_FLAGS_MINSIZEREL-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_RELEASE
-CMAKE_STATIC_LINKER_FLAGS_RELEASE-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO
-CMAKE_STATIC_LINKER_FLAGS_RELWITHDEBINFO-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_STRIP
-CMAKE_STRIP-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_TAPI
-CMAKE_TAPI-ADVANCED:INTERNAL=1
-//ADVANCED property for variable: CMAKE_VERBOSE_MAKEFILE
-CMAKE_VERBOSE_MAKEFILE-ADVANCED:INTERNAL=1
-
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCCompiler.cmake
deleted file mode 100644
index 1b37ed3..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCCompiler.cmake
+++ /dev/null
@@ -1,81 +0,0 @@
-set(CMAKE_C_COMPILER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe")
-set(CMAKE_C_COMPILER_ARG1 "")
-set(CMAKE_C_COMPILER_ID "GNU")
-set(CMAKE_C_COMPILER_VERSION "13.1.0")
-set(CMAKE_C_COMPILER_VERSION_INTERNAL "")
-set(CMAKE_C_COMPILER_WRAPPER "")
-set(CMAKE_C_STANDARD_COMPUTED_DEFAULT "17")
-set(CMAKE_C_EXTENSIONS_COMPUTED_DEFAULT "ON")
-set(CMAKE_C_STANDARD_LATEST "23")
-set(CMAKE_C_COMPILE_FEATURES "c_std_90;c_function_prototypes;c_std_99;c_restrict;c_variadic_macros;c_std_11;c_static_assert;c_std_17;c_std_23")
-set(CMAKE_C90_COMPILE_FEATURES "c_std_90;c_function_prototypes")
-set(CMAKE_C99_COMPILE_FEATURES "c_std_99;c_restrict;c_variadic_macros")
-set(CMAKE_C11_COMPILE_FEATURES "c_std_11;c_static_assert")
-set(CMAKE_C17_COMPILE_FEATURES "c_std_17")
-set(CMAKE_C23_COMPILE_FEATURES "c_std_23")
-
-set(CMAKE_C_PLATFORM_ID "MinGW")
-set(CMAKE_C_SIMULATE_ID "")
-set(CMAKE_C_COMPILER_FRONTEND_VARIANT "GNU")
-set(CMAKE_C_SIMULATE_VERSION "")
-
-
-
-
-set(CMAKE_AR "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe")
-set(CMAKE_C_COMPILER_AR "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe")
-set(CMAKE_RANLIB "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe")
-set(CMAKE_C_COMPILER_RANLIB "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe")
-set(CMAKE_LINKER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_LINKER_LINK "")
-set(CMAKE_LINKER_LLD "")
-set(CMAKE_C_COMPILER_LINKER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_C_COMPILER_LINKER_ID "GNU")
-set(CMAKE_C_COMPILER_LINKER_VERSION 2.40)
-set(CMAKE_C_COMPILER_LINKER_FRONTEND_VARIANT GNU)
-set(CMAKE_MT "")
-set(CMAKE_TAPI "CMAKE_TAPI-NOTFOUND")
-set(CMAKE_COMPILER_IS_GNUCC 1)
-set(CMAKE_C_COMPILER_LOADED 1)
-set(CMAKE_C_COMPILER_WORKS TRUE)
-set(CMAKE_C_ABI_COMPILED TRUE)
-
-set(CMAKE_C_COMPILER_ENV_VAR "CC")
-
-set(CMAKE_C_COMPILER_ID_RUN 1)
-set(CMAKE_C_SOURCE_FILE_EXTENSIONS c;m)
-set(CMAKE_C_IGNORE_EXTENSIONS h;H;o;O;obj;OBJ;def;DEF;rc;RC)
-set(CMAKE_C_LINKER_PREFERENCE 10)
-set(CMAKE_C_LINKER_DEPFILE_SUPPORTED FALSE)
-
-# Save compiler ABI information.
-set(CMAKE_C_SIZEOF_DATA_PTR "8")
-set(CMAKE_C_COMPILER_ABI "")
-set(CMAKE_C_BYTE_ORDER "LITTLE_ENDIAN")
-set(CMAKE_C_LIBRARY_ARCHITECTURE "")
-
-if(CMAKE_C_SIZEOF_DATA_PTR)
- set(CMAKE_SIZEOF_VOID_P "${CMAKE_C_SIZEOF_DATA_PTR}")
-endif()
-
-if(CMAKE_C_COMPILER_ABI)
- set(CMAKE_INTERNAL_PLATFORM_ABI "${CMAKE_C_COMPILER_ABI}")
-endif()
-
-if(CMAKE_C_LIBRARY_ARCHITECTURE)
- set(CMAKE_LIBRARY_ARCHITECTURE "")
-endif()
-
-set(CMAKE_C_CL_SHOWINCLUDES_PREFIX "")
-if(CMAKE_C_CL_SHOWINCLUDES_PREFIX)
- set(CMAKE_CL_SHOWINCLUDES_PREFIX "${CMAKE_C_CL_SHOWINCLUDES_PREFIX}")
-endif()
-
-
-
-
-
-set(CMAKE_C_IMPLICIT_INCLUDE_DIRECTORIES "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include")
-set(CMAKE_C_IMPLICIT_LINK_LIBRARIES "mingw32;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc;moldname;mingwex;kernel32")
-set(CMAKE_C_IMPLICIT_LINK_DIRECTORIES "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib")
-set(CMAKE_C_IMPLICIT_LINK_FRAMEWORK_DIRECTORIES "")
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCXXCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCXXCompiler.cmake
deleted file mode 100644
index d64d803..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeCXXCompiler.cmake
+++ /dev/null
@@ -1,101 +0,0 @@
-set(CMAKE_CXX_COMPILER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe")
-set(CMAKE_CXX_COMPILER_ARG1 "")
-set(CMAKE_CXX_COMPILER_ID "GNU")
-set(CMAKE_CXX_COMPILER_VERSION "13.1.0")
-set(CMAKE_CXX_COMPILER_VERSION_INTERNAL "")
-set(CMAKE_CXX_COMPILER_WRAPPER "")
-set(CMAKE_CXX_STANDARD_COMPUTED_DEFAULT "17")
-set(CMAKE_CXX_EXTENSIONS_COMPUTED_DEFAULT "ON")
-set(CMAKE_CXX_STANDARD_LATEST "23")
-set(CMAKE_CXX_COMPILE_FEATURES "cxx_std_98;cxx_template_template_parameters;cxx_std_11;cxx_alias_templates;cxx_alignas;cxx_alignof;cxx_attributes;cxx_auto_type;cxx_constexpr;cxx_decltype;cxx_decltype_incomplete_return_types;cxx_default_function_template_args;cxx_defaulted_functions;cxx_defaulted_move_initializers;cxx_delegating_constructors;cxx_deleted_functions;cxx_enum_forward_declarations;cxx_explicit_conversions;cxx_extended_friend_declarations;cxx_extern_templates;cxx_final;cxx_func_identifier;cxx_generalized_initializers;cxx_inheriting_constructors;cxx_inline_namespaces;cxx_lambdas;cxx_local_type_template_args;cxx_long_long_type;cxx_noexcept;cxx_nonstatic_member_init;cxx_nullptr;cxx_override;cxx_range_for;cxx_raw_string_literals;cxx_reference_qualified_functions;cxx_right_angle_brackets;cxx_rvalue_references;cxx_sizeof_member;cxx_static_assert;cxx_strong_enums;cxx_thread_local;cxx_trailing_return_types;cxx_unicode_literals;cxx_uniform_initialization;cxx_unrestricted_unions;cxx_user_literals;cxx_variadic_macros;cxx_variadic_templates;cxx_std_14;cxx_aggregate_default_initializers;cxx_attribute_deprecated;cxx_binary_literals;cxx_contextual_conversions;cxx_decltype_auto;cxx_digit_separators;cxx_generic_lambdas;cxx_lambda_init_captures;cxx_relaxed_constexpr;cxx_return_type_deduction;cxx_variable_templates;cxx_std_17;cxx_std_20;cxx_std_23")
-set(CMAKE_CXX98_COMPILE_FEATURES "cxx_std_98;cxx_template_template_parameters")
-set(CMAKE_CXX11_COMPILE_FEATURES "cxx_std_11;cxx_alias_templates;cxx_alignas;cxx_alignof;cxx_attributes;cxx_auto_type;cxx_constexpr;cxx_decltype;cxx_decltype_incomplete_return_types;cxx_default_function_template_args;cxx_defaulted_functions;cxx_defaulted_move_initializers;cxx_delegating_constructors;cxx_deleted_functions;cxx_enum_forward_declarations;cxx_explicit_conversions;cxx_extended_friend_declarations;cxx_extern_templates;cxx_final;cxx_func_identifier;cxx_generalized_initializers;cxx_inheriting_constructors;cxx_inline_namespaces;cxx_lambdas;cxx_local_type_template_args;cxx_long_long_type;cxx_noexcept;cxx_nonstatic_member_init;cxx_nullptr;cxx_override;cxx_range_for;cxx_raw_string_literals;cxx_reference_qualified_functions;cxx_right_angle_brackets;cxx_rvalue_references;cxx_sizeof_member;cxx_static_assert;cxx_strong_enums;cxx_thread_local;cxx_trailing_return_types;cxx_unicode_literals;cxx_uniform_initialization;cxx_unrestricted_unions;cxx_user_literals;cxx_variadic_macros;cxx_variadic_templates")
-set(CMAKE_CXX14_COMPILE_FEATURES "cxx_std_14;cxx_aggregate_default_initializers;cxx_attribute_deprecated;cxx_binary_literals;cxx_contextual_conversions;cxx_decltype_auto;cxx_digit_separators;cxx_generic_lambdas;cxx_lambda_init_captures;cxx_relaxed_constexpr;cxx_return_type_deduction;cxx_variable_templates")
-set(CMAKE_CXX17_COMPILE_FEATURES "cxx_std_17")
-set(CMAKE_CXX20_COMPILE_FEATURES "cxx_std_20")
-set(CMAKE_CXX23_COMPILE_FEATURES "cxx_std_23")
-set(CMAKE_CXX26_COMPILE_FEATURES "")
-
-set(CMAKE_CXX_PLATFORM_ID "MinGW")
-set(CMAKE_CXX_SIMULATE_ID "")
-set(CMAKE_CXX_COMPILER_FRONTEND_VARIANT "GNU")
-set(CMAKE_CXX_SIMULATE_VERSION "")
-
-
-
-
-set(CMAKE_AR "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe")
-set(CMAKE_CXX_COMPILER_AR "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe")
-set(CMAKE_RANLIB "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe")
-set(CMAKE_CXX_COMPILER_RANLIB "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe")
-set(CMAKE_LINKER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_LINKER_LINK "")
-set(CMAKE_LINKER_LLD "")
-set(CMAKE_CXX_COMPILER_LINKER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_CXX_COMPILER_LINKER_ID "GNU")
-set(CMAKE_CXX_COMPILER_LINKER_VERSION 2.40)
-set(CMAKE_CXX_COMPILER_LINKER_FRONTEND_VARIANT GNU)
-set(CMAKE_MT "")
-set(CMAKE_TAPI "CMAKE_TAPI-NOTFOUND")
-set(CMAKE_COMPILER_IS_GNUCXX 1)
-set(CMAKE_CXX_COMPILER_LOADED 1)
-set(CMAKE_CXX_COMPILER_WORKS TRUE)
-set(CMAKE_CXX_ABI_COMPILED TRUE)
-
-set(CMAKE_CXX_COMPILER_ENV_VAR "CXX")
-
-set(CMAKE_CXX_COMPILER_ID_RUN 1)
-set(CMAKE_CXX_SOURCE_FILE_EXTENSIONS C;M;c++;cc;cpp;cxx;m;mm;mpp;CPP;ixx;cppm;ccm;cxxm;c++m)
-set(CMAKE_CXX_IGNORE_EXTENSIONS inl;h;hpp;HPP;H;o;O;obj;OBJ;def;DEF;rc;RC)
-
-foreach (lang IN ITEMS C OBJC OBJCXX)
- if (CMAKE_${lang}_COMPILER_ID_RUN)
- foreach(extension IN LISTS CMAKE_${lang}_SOURCE_FILE_EXTENSIONS)
- list(REMOVE_ITEM CMAKE_CXX_SOURCE_FILE_EXTENSIONS ${extension})
- endforeach()
- endif()
-endforeach()
-
-set(CMAKE_CXX_LINKER_PREFERENCE 30)
-set(CMAKE_CXX_LINKER_PREFERENCE_PROPAGATES 1)
-set(CMAKE_CXX_LINKER_DEPFILE_SUPPORTED FALSE)
-
-# Save compiler ABI information.
-set(CMAKE_CXX_SIZEOF_DATA_PTR "8")
-set(CMAKE_CXX_COMPILER_ABI "")
-set(CMAKE_CXX_BYTE_ORDER "LITTLE_ENDIAN")
-set(CMAKE_CXX_LIBRARY_ARCHITECTURE "")
-
-if(CMAKE_CXX_SIZEOF_DATA_PTR)
- set(CMAKE_SIZEOF_VOID_P "${CMAKE_CXX_SIZEOF_DATA_PTR}")
-endif()
-
-if(CMAKE_CXX_COMPILER_ABI)
- set(CMAKE_INTERNAL_PLATFORM_ABI "${CMAKE_CXX_COMPILER_ABI}")
-endif()
-
-if(CMAKE_CXX_LIBRARY_ARCHITECTURE)
- set(CMAKE_LIBRARY_ARCHITECTURE "")
-endif()
-
-set(CMAKE_CXX_CL_SHOWINCLUDES_PREFIX "")
-if(CMAKE_CXX_CL_SHOWINCLUDES_PREFIX)
- set(CMAKE_CL_SHOWINCLUDES_PREFIX "${CMAKE_CXX_CL_SHOWINCLUDES_PREFIX}")
-endif()
-
-
-
-
-
-set(CMAKE_CXX_IMPLICIT_INCLUDE_DIRECTORIES "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include")
-set(CMAKE_CXX_IMPLICIT_LINK_LIBRARIES "stdc++;mingw32;gcc_s;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc_s;gcc;moldname;mingwex;kernel32")
-set(CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/lib")
-set(CMAKE_CXX_IMPLICIT_LINK_FRAMEWORK_DIRECTORIES "")
-set(CMAKE_CXX_COMPILER_CLANG_RESOURCE_DIR "")
-
-set(CMAKE_CXX_COMPILER_IMPORT_STD "")
-### Imported target for C++23 standard library
-set(CMAKE_CXX23_COMPILER_IMPORT_STD_NOT_FOUND_MESSAGE "Toolchain does not support discovering `import std` support")
-
-
-
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_C.bin b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_C.bin
deleted file mode 100644
index af79075..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_C.bin and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_CXX.bin b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_CXX.bin
deleted file mode 100644
index bc7e48b..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeDetermineCompilerABI_CXX.bin and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeRCCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeRCCompiler.cmake
deleted file mode 100644
index d07598f..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeRCCompiler.cmake
+++ /dev/null
@@ -1,6 +0,0 @@
-set(CMAKE_RC_COMPILER "C:/Users/thebe/AppData/Local/Programs/CLion/bin/mingw/bin/windres.exe")
-set(CMAKE_RC_COMPILER_ARG1 "")
-set(CMAKE_RC_COMPILER_LOADED 1)
-set(CMAKE_RC_SOURCE_FILE_EXTENSIONS rc;RC)
-set(CMAKE_RC_OUTPUT_EXTENSION .obj)
-set(CMAKE_RC_COMPILER_ENV_VAR "RC")
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeSystem.cmake b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeSystem.cmake
deleted file mode 100644
index 000cf69..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CMakeSystem.cmake
+++ /dev/null
@@ -1,15 +0,0 @@
-set(CMAKE_HOST_SYSTEM "Windows-10.0.26100")
-set(CMAKE_HOST_SYSTEM_NAME "Windows")
-set(CMAKE_HOST_SYSTEM_VERSION "10.0.26100")
-set(CMAKE_HOST_SYSTEM_PROCESSOR "AMD64")
-
-
-
-set(CMAKE_SYSTEM "Windows-10.0.26100")
-set(CMAKE_SYSTEM_NAME "Windows")
-set(CMAKE_SYSTEM_VERSION "10.0.26100")
-set(CMAKE_SYSTEM_PROCESSOR "AMD64")
-
-set(CMAKE_CROSSCOMPILING "FALSE")
-
-set(CMAKE_SYSTEM_LOADED 1)
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/CMakeCCompilerId.c b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/CMakeCCompilerId.c
deleted file mode 100644
index 8d8bb03..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/CMakeCCompilerId.c
+++ /dev/null
@@ -1,904 +0,0 @@
-#ifdef __cplusplus
-# error "A C++ compiler has been selected for C."
-#endif
-
-#if defined(__18CXX)
-# define ID_VOID_MAIN
-#endif
-#if defined(__CLASSIC_C__)
-/* cv-qualifiers did not exist in K&R C */
-# define const
-# define volatile
-#endif
-
-#if !defined(__has_include)
-/* If the compiler does not have __has_include, pretend the answer is
- always no. */
-# define __has_include(x) 0
-#endif
-
-
-/* Version number components: V=Version, R=Revision, P=Patch
- Version date components: YYYY=Year, MM=Month, DD=Day */
-
-#if defined(__INTEL_COMPILER) || defined(__ICC)
-# define COMPILER_ID "Intel"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-# endif
- /* __INTEL_COMPILER = VRP prior to 2021, and then VVVV for 2021 and later,
- except that a few beta releases use the old format with V=2021. */
-# if __INTEL_COMPILER < 2021 || __INTEL_COMPILER == 202110 || __INTEL_COMPILER == 202111
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10)
-# if defined(__INTEL_COMPILER_UPDATE)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE)
-# else
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10)
-# endif
-# else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER_UPDATE)
- /* The third version component from --version is an update index,
- but no macro is provided for it. */
-# define COMPILER_VERSION_PATCH DEC(0)
-# endif
-# if defined(__INTEL_COMPILER_BUILD_DATE)
- /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */
-# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE)
-# endif
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif (defined(__clang__) && defined(__INTEL_CLANG_COMPILER)) || defined(__INTEL_LLVM_COMPILER)
-# define COMPILER_ID "IntelLLVM"
-#if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-#endif
-/* __INTEL_LLVM_COMPILER = VVVVRP prior to 2021.2.0, VVVVRRPP for 2021.2.0 and
- * later. Look for 6 digit vs. 8 digit version number to decide encoding.
- * VVVV is no smaller than the current year when a version is released.
- */
-#if __INTEL_LLVM_COMPILER < 1000000L
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 10)
-#else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/10000)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 100)
-#endif
-#if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-#elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-#endif
-#if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-#endif
-#if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-#endif
-
-#elif defined(__PATHCC__)
-# define COMPILER_ID "PathScale"
-# define COMPILER_VERSION_MAJOR DEC(__PATHCC__)
-# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__)
-# if defined(__PATHCC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__)
-# endif
-
-#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__)
-# define COMPILER_ID "Embarcadero"
-# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF)
-# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF)
-# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF)
-
-#elif defined(__BORLANDC__)
-# define COMPILER_ID "Borland"
- /* __BORLANDC__ = 0xVRR */
-# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8)
-# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF)
-
-#elif defined(__WATCOMC__) && __WATCOMC__ < 1200
-# define COMPILER_ID "Watcom"
- /* __WATCOMC__ = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__WATCOMC__)
-# define COMPILER_ID "OpenWatcom"
- /* __WATCOMC__ = VVRP + 1100 */
-# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__SUNPRO_C)
-# define COMPILER_ID "SunPro"
-# if __SUNPRO_C >= 0x5100
- /* __SUNPRO_C = 0xVRRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>12)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xFF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
-# else
- /* __SUNPRO_CC = 0xVRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>8)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
-# endif
-
-#elif defined(__HP_cc)
-# define COMPILER_ID "HP"
- /* __HP_cc = VVRRPP */
-# define COMPILER_VERSION_MAJOR DEC(__HP_cc/10000)
-# define COMPILER_VERSION_MINOR DEC(__HP_cc/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__HP_cc % 100)
-
-#elif defined(__DECC)
-# define COMPILER_ID "Compaq"
- /* __DECC_VER = VVRRTPPPP */
-# define COMPILER_VERSION_MAJOR DEC(__DECC_VER/10000000)
-# define COMPILER_VERSION_MINOR DEC(__DECC_VER/100000 % 100)
-# define COMPILER_VERSION_PATCH DEC(__DECC_VER % 10000)
-
-#elif defined(__IBMC__) && defined(__COMPILER_VER__)
-# define COMPILER_ID "zOS"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__open_xl__) && defined(__clang__)
-# define COMPILER_ID "IBMClang"
-# define COMPILER_VERSION_MAJOR DEC(__open_xl_version__)
-# define COMPILER_VERSION_MINOR DEC(__open_xl_release__)
-# define COMPILER_VERSION_PATCH DEC(__open_xl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__open_xl_ptf_fix_level__)
-
-
-#elif defined(__ibmxl__) && defined(__clang__)
-# define COMPILER_ID "XLClang"
-# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__)
-# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__)
-# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__)
-
-
-#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ >= 800
-# define COMPILER_ID "XL"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ < 800
-# define COMPILER_ID "VisualAge"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__NVCOMPILER)
-# define COMPILER_ID "NVHPC"
-# define COMPILER_VERSION_MAJOR DEC(__NVCOMPILER_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__NVCOMPILER_MINOR__)
-# if defined(__NVCOMPILER_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__NVCOMPILER_PATCHLEVEL__)
-# endif
-
-#elif defined(__PGI)
-# define COMPILER_ID "PGI"
-# define COMPILER_VERSION_MAJOR DEC(__PGIC__)
-# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__)
-# if defined(__PGIC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__)
-# endif
-
-#elif defined(__clang__) && defined(__cray__)
-# define COMPILER_ID "CrayClang"
-# define COMPILER_VERSION_MAJOR DEC(__cray_major__)
-# define COMPILER_VERSION_MINOR DEC(__cray_minor__)
-# define COMPILER_VERSION_PATCH DEC(__cray_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(_CRAYC)
-# define COMPILER_ID "Cray"
-# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR)
-
-#elif defined(__TI_COMPILER_VERSION__)
-# define COMPILER_ID "TI"
- /* __TI_COMPILER_VERSION__ = VVVRRRPPP */
-# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000)
-# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000)
-# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000)
-
-#elif defined(__CLANG_FUJITSU)
-# define COMPILER_ID "FujitsuClang"
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__FUJITSU)
-# define COMPILER_ID "Fujitsu"
-# if defined(__FCC_version__)
-# define COMPILER_VERSION __FCC_version__
-# elif defined(__FCC_major__)
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# endif
-# if defined(__fcc_version)
-# define COMPILER_VERSION_INTERNAL DEC(__fcc_version)
-# elif defined(__FCC_VERSION)
-# define COMPILER_VERSION_INTERNAL DEC(__FCC_VERSION)
-# endif
-
-
-#elif defined(__ghs__)
-# define COMPILER_ID "GHS"
-/* __GHS_VERSION_NUMBER = VVVVRP */
-# ifdef __GHS_VERSION_NUMBER
-# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100)
-# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10)
-# endif
-
-#elif defined(__TASKING__)
-# define COMPILER_ID "Tasking"
- # define COMPILER_VERSION_MAJOR DEC(__VERSION__/1000)
- # define COMPILER_VERSION_MINOR DEC(__VERSION__ % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__VERSION__)
-
-#elif defined(__ORANGEC__)
-# define COMPILER_ID "OrangeC"
-# define COMPILER_VERSION_MAJOR DEC(__ORANGEC_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__ORANGEC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__ORANGEC_PATCHLEVEL__)
-
-#elif defined(__TINYC__)
-# define COMPILER_ID "TinyCC"
-
-#elif defined(__BCC__)
-# define COMPILER_ID "Bruce"
-
-#elif defined(__SCO_VERSION__)
-# define COMPILER_ID "SCO"
-
-#elif defined(__ARMCC_VERSION) && !defined(__clang__)
-# define COMPILER_ID "ARMCC"
-#if __ARMCC_VERSION >= 1000000
- /* __ARMCC_VERSION = VRRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#else
- /* __ARMCC_VERSION = VRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#endif
-
-
-#elif defined(__clang__) && defined(__apple_build_version__)
-# define COMPILER_ID "AppleClang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__)
-
-#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION)
-# define COMPILER_ID "ARMClang"
- # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION/100 % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION)
-
-#elif defined(__clang__) && defined(__ti__)
-# define COMPILER_ID "TIClang"
- # define COMPILER_VERSION_MAJOR DEC(__ti_major__)
- # define COMPILER_VERSION_MINOR DEC(__ti_minor__)
- # define COMPILER_VERSION_PATCH DEC(__ti_patchlevel__)
-# define COMPILER_VERSION_INTERNAL DEC(__ti_version__)
-
-#elif defined(__clang__)
-# define COMPILER_ID "Clang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-
-#elif defined(__LCC__) && (defined(__GNUC__) || defined(__GNUG__) || defined(__MCST__))
-# define COMPILER_ID "LCC"
-# define COMPILER_VERSION_MAJOR DEC(__LCC__ / 100)
-# define COMPILER_VERSION_MINOR DEC(__LCC__ % 100)
-# if defined(__LCC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__LCC_MINOR__)
-# endif
-# if defined(__GNUC__) && defined(__GNUC_MINOR__)
-# define SIMULATE_ID "GNU"
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-# endif
-
-#elif defined(__GNUC__)
-# define COMPILER_ID "GNU"
-# define COMPILER_VERSION_MAJOR DEC(__GNUC__)
-# if defined(__GNUC_MINOR__)
-# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif defined(_MSC_VER)
-# define COMPILER_ID "MSVC"
- /* _MSC_VER = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100)
-# if defined(_MSC_FULL_VER)
-# if _MSC_VER >= 1400
- /* _MSC_FULL_VER = VVRRPPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000)
-# else
- /* _MSC_FULL_VER = VVRRPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000)
-# endif
-# endif
-# if defined(_MSC_BUILD)
-# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD)
-# endif
-
-#elif defined(_ADI_COMPILER)
-# define COMPILER_ID "ADSP"
-#if defined(__VERSIONNUM__)
- /* __VERSIONNUM__ = 0xVVRRPPTT */
-# define COMPILER_VERSION_MAJOR DEC(__VERSIONNUM__ >> 24 & 0xFF)
-# define COMPILER_VERSION_MINOR DEC(__VERSIONNUM__ >> 16 & 0xFF)
-# define COMPILER_VERSION_PATCH DEC(__VERSIONNUM__ >> 8 & 0xFF)
-# define COMPILER_VERSION_TWEAK DEC(__VERSIONNUM__ & 0xFF)
-#endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# define COMPILER_ID "IAR"
-# if defined(__VER__) && defined(__ICCARM__)
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000)
-# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000)
-# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__) || defined(__ICCSTM8__))
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100)
-# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100))
-# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# endif
-
-#elif defined(__SDCC_VERSION_MAJOR) || defined(SDCC)
-# define COMPILER_ID "SDCC"
-# if defined(__SDCC_VERSION_MAJOR)
-# define COMPILER_VERSION_MAJOR DEC(__SDCC_VERSION_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(__SDCC_VERSION_MINOR)
-# define COMPILER_VERSION_PATCH DEC(__SDCC_VERSION_PATCH)
-# else
- /* SDCC = VRP */
-# define COMPILER_VERSION_MAJOR DEC(SDCC/100)
-# define COMPILER_VERSION_MINOR DEC(SDCC/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(SDCC % 10)
-# endif
-
-
-/* These compilers are either not known or too old to define an
- identification macro. Try to identify the platform and guess that
- it is the native compiler. */
-#elif defined(__hpux) || defined(__hpua)
-# define COMPILER_ID "HP"
-
-#else /* unknown compiler */
-# define COMPILER_ID ""
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]";
-#ifdef SIMULATE_ID
-char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]";
-#endif
-
-#ifdef __QNXNTO__
-char const* qnxnto = "INFO" ":" "qnxnto[]";
-#endif
-
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
-char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]";
-#endif
-
-#define STRINGIFY_HELPER(X) #X
-#define STRINGIFY(X) STRINGIFY_HELPER(X)
-
-/* Identify known platforms by name. */
-#if defined(__linux) || defined(__linux__) || defined(linux)
-# define PLATFORM_ID "Linux"
-
-#elif defined(__MSYS__)
-# define PLATFORM_ID "MSYS"
-
-#elif defined(__CYGWIN__)
-# define PLATFORM_ID "Cygwin"
-
-#elif defined(__MINGW32__)
-# define PLATFORM_ID "MinGW"
-
-#elif defined(__APPLE__)
-# define PLATFORM_ID "Darwin"
-
-#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
-# define PLATFORM_ID "Windows"
-
-#elif defined(__FreeBSD__) || defined(__FreeBSD)
-# define PLATFORM_ID "FreeBSD"
-
-#elif defined(__NetBSD__) || defined(__NetBSD)
-# define PLATFORM_ID "NetBSD"
-
-#elif defined(__OpenBSD__) || defined(__OPENBSD)
-# define PLATFORM_ID "OpenBSD"
-
-#elif defined(__sun) || defined(sun)
-# define PLATFORM_ID "SunOS"
-
-#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__)
-# define PLATFORM_ID "AIX"
-
-#elif defined(__hpux) || defined(__hpux__)
-# define PLATFORM_ID "HP-UX"
-
-#elif defined(__HAIKU__)
-# define PLATFORM_ID "Haiku"
-
-#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS)
-# define PLATFORM_ID "BeOS"
-
-#elif defined(__QNX__) || defined(__QNXNTO__)
-# define PLATFORM_ID "QNX"
-
-#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__)
-# define PLATFORM_ID "Tru64"
-
-#elif defined(__riscos) || defined(__riscos__)
-# define PLATFORM_ID "RISCos"
-
-#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__)
-# define PLATFORM_ID "SINIX"
-
-#elif defined(__UNIX_SV__)
-# define PLATFORM_ID "UNIX_SV"
-
-#elif defined(__bsdos__)
-# define PLATFORM_ID "BSDOS"
-
-#elif defined(_MPRAS) || defined(MPRAS)
-# define PLATFORM_ID "MP-RAS"
-
-#elif defined(__osf) || defined(__osf__)
-# define PLATFORM_ID "OSF1"
-
-#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv)
-# define PLATFORM_ID "SCO_SV"
-
-#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX)
-# define PLATFORM_ID "ULTRIX"
-
-#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX)
-# define PLATFORM_ID "Xenix"
-
-#elif defined(__WATCOMC__)
-# if defined(__LINUX__)
-# define PLATFORM_ID "Linux"
-
-# elif defined(__DOS__)
-# define PLATFORM_ID "DOS"
-
-# elif defined(__OS2__)
-# define PLATFORM_ID "OS2"
-
-# elif defined(__WINDOWS__)
-# define PLATFORM_ID "Windows3x"
-
-# elif defined(__VXWORKS__)
-# define PLATFORM_ID "VxWorks"
-
-# else /* unknown platform */
-# define PLATFORM_ID
-# endif
-
-#elif defined(__INTEGRITY)
-# if defined(INT_178B)
-# define PLATFORM_ID "Integrity178"
-
-# else /* regular Integrity */
-# define PLATFORM_ID "Integrity"
-# endif
-
-# elif defined(_ADI_COMPILER)
-# define PLATFORM_ID "ADSP"
-
-#else /* unknown platform */
-# define PLATFORM_ID
-
-#endif
-
-/* For windows compilers MSVC and Intel we can determine
- the architecture of the compiler being used. This is because
- the compilers do not have flags that can change the architecture,
- but rather depend on which compiler is being used
-*/
-#if defined(_WIN32) && defined(_MSC_VER)
-# if defined(_M_IA64)
-# define ARCHITECTURE_ID "IA64"
-
-# elif defined(_M_ARM64EC)
-# define ARCHITECTURE_ID "ARM64EC"
-
-# elif defined(_M_X64) || defined(_M_AMD64)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# elif defined(_M_ARM64)
-# define ARCHITECTURE_ID "ARM64"
-
-# elif defined(_M_ARM)
-# if _M_ARM == 4
-# define ARCHITECTURE_ID "ARMV4I"
-# elif _M_ARM == 5
-# define ARCHITECTURE_ID "ARMV5I"
-# else
-# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM)
-# endif
-
-# elif defined(_M_MIPS)
-# define ARCHITECTURE_ID "MIPS"
-
-# elif defined(_M_SH)
-# define ARCHITECTURE_ID "SHx"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__WATCOMC__)
-# if defined(_M_I86)
-# define ARCHITECTURE_ID "I86"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# if defined(__ICCARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__ICCRX__)
-# define ARCHITECTURE_ID "RX"
-
-# elif defined(__ICCRH850__)
-# define ARCHITECTURE_ID "RH850"
-
-# elif defined(__ICCRL78__)
-# define ARCHITECTURE_ID "RL78"
-
-# elif defined(__ICCRISCV__)
-# define ARCHITECTURE_ID "RISCV"
-
-# elif defined(__ICCAVR__)
-# define ARCHITECTURE_ID "AVR"
-
-# elif defined(__ICC430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__ICCV850__)
-# define ARCHITECTURE_ID "V850"
-
-# elif defined(__ICC8051__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__ICCSTM8__)
-# define ARCHITECTURE_ID "STM8"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__ghs__)
-# if defined(__PPC64__)
-# define ARCHITECTURE_ID "PPC64"
-
-# elif defined(__ppc__)
-# define ARCHITECTURE_ID "PPC"
-
-# elif defined(__ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__x86_64__)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(__i386__)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__clang__) && defined(__ti__)
-# if defined(__ARM_ARCH)
-# define ARCHITECTURE_ID "Arm"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__TI_COMPILER_VERSION__)
-# if defined(__TI_ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__MSP430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__TMS320C28XX__)
-# define ARCHITECTURE_ID "TMS320C28x"
-
-# elif defined(__TMS320C6X__) || defined(_TMS320C6X)
-# define ARCHITECTURE_ID "TMS320C6x"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-# elif defined(__ADSPSHARC__)
-# define ARCHITECTURE_ID "SHARC"
-
-# elif defined(__ADSPBLACKFIN__)
-# define ARCHITECTURE_ID "Blackfin"
-
-#elif defined(__TASKING__)
-
-# if defined(__CTC__) || defined(__CPTC__)
-# define ARCHITECTURE_ID "TriCore"
-
-# elif defined(__CMCS__)
-# define ARCHITECTURE_ID "MCS"
-
-# elif defined(__CARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__CARC__)
-# define ARCHITECTURE_ID "ARC"
-
-# elif defined(__C51__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__CPCP__)
-# define ARCHITECTURE_ID "PCP"
-
-# else
-# define ARCHITECTURE_ID ""
-# endif
-
-#else
-# define ARCHITECTURE_ID
-#endif
-
-/* Convert integer to decimal digit literals. */
-#define DEC(n) \
- ('0' + (((n) / 10000000)%10)), \
- ('0' + (((n) / 1000000)%10)), \
- ('0' + (((n) / 100000)%10)), \
- ('0' + (((n) / 10000)%10)), \
- ('0' + (((n) / 1000)%10)), \
- ('0' + (((n) / 100)%10)), \
- ('0' + (((n) / 10)%10)), \
- ('0' + ((n) % 10))
-
-/* Convert integer to hex digit literals. */
-#define HEX(n) \
- ('0' + ((n)>>28 & 0xF)), \
- ('0' + ((n)>>24 & 0xF)), \
- ('0' + ((n)>>20 & 0xF)), \
- ('0' + ((n)>>16 & 0xF)), \
- ('0' + ((n)>>12 & 0xF)), \
- ('0' + ((n)>>8 & 0xF)), \
- ('0' + ((n)>>4 & 0xF)), \
- ('0' + ((n) & 0xF))
-
-/* Construct a string literal encoding the version number. */
-#ifdef COMPILER_VERSION
-char const* info_version = "INFO" ":" "compiler_version[" COMPILER_VERSION "]";
-
-/* Construct a string literal encoding the version number components. */
-#elif defined(COMPILER_VERSION_MAJOR)
-char const info_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[',
- COMPILER_VERSION_MAJOR,
-# ifdef COMPILER_VERSION_MINOR
- '.', COMPILER_VERSION_MINOR,
-# ifdef COMPILER_VERSION_PATCH
- '.', COMPILER_VERSION_PATCH,
-# ifdef COMPILER_VERSION_TWEAK
- '.', COMPILER_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct a string literal encoding the internal version number. */
-#ifdef COMPILER_VERSION_INTERNAL
-char const info_version_internal[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_',
- 'i','n','t','e','r','n','a','l','[',
- COMPILER_VERSION_INTERNAL,']','\0'};
-#elif defined(COMPILER_VERSION_INTERNAL_STR)
-char const* info_version_internal = "INFO" ":" "compiler_version_internal[" COMPILER_VERSION_INTERNAL_STR "]";
-#endif
-
-/* Construct a string literal encoding the version number components. */
-#ifdef SIMULATE_VERSION_MAJOR
-char const info_simulate_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[',
- SIMULATE_VERSION_MAJOR,
-# ifdef SIMULATE_VERSION_MINOR
- '.', SIMULATE_VERSION_MINOR,
-# ifdef SIMULATE_VERSION_PATCH
- '.', SIMULATE_VERSION_PATCH,
-# ifdef SIMULATE_VERSION_TWEAK
- '.', SIMULATE_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]";
-char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]";
-
-
-
-#define C_STD_99 199901L
-#define C_STD_11 201112L
-#define C_STD_17 201710L
-#define C_STD_23 202311L
-
-#ifdef __STDC_VERSION__
-# define C_STD __STDC_VERSION__
-#endif
-
-#if !defined(__STDC__) && !defined(__clang__)
-# if defined(_MSC_VER) || defined(__ibmxl__) || defined(__IBMC__)
-# define C_VERSION "90"
-# else
-# define C_VERSION
-# endif
-#elif C_STD > C_STD_17
-# define C_VERSION "23"
-#elif C_STD > C_STD_11
-# define C_VERSION "17"
-#elif C_STD > C_STD_99
-# define C_VERSION "11"
-#elif C_STD >= C_STD_99
-# define C_VERSION "99"
-#else
-# define C_VERSION "90"
-#endif
-const char* info_language_standard_default =
- "INFO" ":" "standard_default[" C_VERSION "]";
-
-const char* info_language_extensions_default = "INFO" ":" "extensions_default["
-#if (defined(__clang__) || defined(__GNUC__) || defined(__xlC__) || \
- defined(__TI_COMPILER_VERSION__)) && \
- !defined(__STRICT_ANSI__)
- "ON"
-#else
- "OFF"
-#endif
-"]";
-
-/*--------------------------------------------------------------------------*/
-
-#ifdef ID_VOID_MAIN
-void main() {}
-#else
-# if defined(__CLASSIC_C__)
-int main(argc, argv) int argc; char *argv[];
-# else
-int main(int argc, char* argv[])
-# endif
-{
- int require = 0;
- require += info_compiler[argc];
- require += info_platform[argc];
- require += info_arch[argc];
-#ifdef COMPILER_VERSION_MAJOR
- require += info_version[argc];
-#endif
-#ifdef COMPILER_VERSION_INTERNAL
- require += info_version_internal[argc];
-#endif
-#ifdef SIMULATE_ID
- require += info_simulate[argc];
-#endif
-#ifdef SIMULATE_VERSION_MAJOR
- require += info_simulate_version[argc];
-#endif
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
- require += info_cray[argc];
-#endif
- require += info_language_standard_default[argc];
- require += info_language_extensions_default[argc];
- (void)argv;
- return require;
-}
-#endif
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/a.exe b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/a.exe
deleted file mode 100644
index 1d1f978..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdC/a.exe and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/CMakeCXXCompilerId.cpp b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/CMakeCXXCompilerId.cpp
deleted file mode 100644
index da6c824..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/CMakeCXXCompilerId.cpp
+++ /dev/null
@@ -1,919 +0,0 @@
-/* This source file must have a .cpp extension so that all C++ compilers
- recognize the extension without flags. Borland does not know .cxx for
- example. */
-#ifndef __cplusplus
-# error "A C compiler has been selected for C++."
-#endif
-
-#if !defined(__has_include)
-/* If the compiler does not have __has_include, pretend the answer is
- always no. */
-# define __has_include(x) 0
-#endif
-
-
-/* Version number components: V=Version, R=Revision, P=Patch
- Version date components: YYYY=Year, MM=Month, DD=Day */
-
-#if defined(__INTEL_COMPILER) || defined(__ICC)
-# define COMPILER_ID "Intel"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-# endif
- /* __INTEL_COMPILER = VRP prior to 2021, and then VVVV for 2021 and later,
- except that a few beta releases use the old format with V=2021. */
-# if __INTEL_COMPILER < 2021 || __INTEL_COMPILER == 202110 || __INTEL_COMPILER == 202111
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10)
-# if defined(__INTEL_COMPILER_UPDATE)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE)
-# else
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10)
-# endif
-# else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER_UPDATE)
- /* The third version component from --version is an update index,
- but no macro is provided for it. */
-# define COMPILER_VERSION_PATCH DEC(0)
-# endif
-# if defined(__INTEL_COMPILER_BUILD_DATE)
- /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */
-# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE)
-# endif
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif (defined(__clang__) && defined(__INTEL_CLANG_COMPILER)) || defined(__INTEL_LLVM_COMPILER)
-# define COMPILER_ID "IntelLLVM"
-#if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-#endif
-/* __INTEL_LLVM_COMPILER = VVVVRP prior to 2021.2.0, VVVVRRPP for 2021.2.0 and
- * later. Look for 6 digit vs. 8 digit version number to decide encoding.
- * VVVV is no smaller than the current year when a version is released.
- */
-#if __INTEL_LLVM_COMPILER < 1000000L
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 10)
-#else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/10000)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 100)
-#endif
-#if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-#elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-#endif
-#if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-#endif
-#if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-#endif
-
-#elif defined(__PATHCC__)
-# define COMPILER_ID "PathScale"
-# define COMPILER_VERSION_MAJOR DEC(__PATHCC__)
-# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__)
-# if defined(__PATHCC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__)
-# endif
-
-#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__)
-# define COMPILER_ID "Embarcadero"
-# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF)
-# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF)
-# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF)
-
-#elif defined(__BORLANDC__)
-# define COMPILER_ID "Borland"
- /* __BORLANDC__ = 0xVRR */
-# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8)
-# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF)
-
-#elif defined(__WATCOMC__) && __WATCOMC__ < 1200
-# define COMPILER_ID "Watcom"
- /* __WATCOMC__ = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__WATCOMC__)
-# define COMPILER_ID "OpenWatcom"
- /* __WATCOMC__ = VVRP + 1100 */
-# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__SUNPRO_CC)
-# define COMPILER_ID "SunPro"
-# if __SUNPRO_CC >= 0x5100
- /* __SUNPRO_CC = 0xVRRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>12)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xFF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF)
-# else
- /* __SUNPRO_CC = 0xVRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>8)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF)
-# endif
-
-#elif defined(__HP_aCC)
-# define COMPILER_ID "HP"
- /* __HP_aCC = VVRRPP */
-# define COMPILER_VERSION_MAJOR DEC(__HP_aCC/10000)
-# define COMPILER_VERSION_MINOR DEC(__HP_aCC/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__HP_aCC % 100)
-
-#elif defined(__DECCXX)
-# define COMPILER_ID "Compaq"
- /* __DECCXX_VER = VVRRTPPPP */
-# define COMPILER_VERSION_MAJOR DEC(__DECCXX_VER/10000000)
-# define COMPILER_VERSION_MINOR DEC(__DECCXX_VER/100000 % 100)
-# define COMPILER_VERSION_PATCH DEC(__DECCXX_VER % 10000)
-
-#elif defined(__IBMCPP__) && defined(__COMPILER_VER__)
-# define COMPILER_ID "zOS"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__open_xl__) && defined(__clang__)
-# define COMPILER_ID "IBMClang"
-# define COMPILER_VERSION_MAJOR DEC(__open_xl_version__)
-# define COMPILER_VERSION_MINOR DEC(__open_xl_release__)
-# define COMPILER_VERSION_PATCH DEC(__open_xl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__open_xl_ptf_fix_level__)
-
-
-#elif defined(__ibmxl__) && defined(__clang__)
-# define COMPILER_ID "XLClang"
-# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__)
-# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__)
-# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__)
-
-
-#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ >= 800
-# define COMPILER_ID "XL"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ < 800
-# define COMPILER_ID "VisualAge"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__NVCOMPILER)
-# define COMPILER_ID "NVHPC"
-# define COMPILER_VERSION_MAJOR DEC(__NVCOMPILER_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__NVCOMPILER_MINOR__)
-# if defined(__NVCOMPILER_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__NVCOMPILER_PATCHLEVEL__)
-# endif
-
-#elif defined(__PGI)
-# define COMPILER_ID "PGI"
-# define COMPILER_VERSION_MAJOR DEC(__PGIC__)
-# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__)
-# if defined(__PGIC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__)
-# endif
-
-#elif defined(__clang__) && defined(__cray__)
-# define COMPILER_ID "CrayClang"
-# define COMPILER_VERSION_MAJOR DEC(__cray_major__)
-# define COMPILER_VERSION_MINOR DEC(__cray_minor__)
-# define COMPILER_VERSION_PATCH DEC(__cray_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(_CRAYC)
-# define COMPILER_ID "Cray"
-# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR)
-
-#elif defined(__TI_COMPILER_VERSION__)
-# define COMPILER_ID "TI"
- /* __TI_COMPILER_VERSION__ = VVVRRRPPP */
-# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000)
-# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000)
-# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000)
-
-#elif defined(__CLANG_FUJITSU)
-# define COMPILER_ID "FujitsuClang"
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__FUJITSU)
-# define COMPILER_ID "Fujitsu"
-# if defined(__FCC_version__)
-# define COMPILER_VERSION __FCC_version__
-# elif defined(__FCC_major__)
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# endif
-# if defined(__fcc_version)
-# define COMPILER_VERSION_INTERNAL DEC(__fcc_version)
-# elif defined(__FCC_VERSION)
-# define COMPILER_VERSION_INTERNAL DEC(__FCC_VERSION)
-# endif
-
-
-#elif defined(__ghs__)
-# define COMPILER_ID "GHS"
-/* __GHS_VERSION_NUMBER = VVVVRP */
-# ifdef __GHS_VERSION_NUMBER
-# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100)
-# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10)
-# endif
-
-#elif defined(__TASKING__)
-# define COMPILER_ID "Tasking"
- # define COMPILER_VERSION_MAJOR DEC(__VERSION__/1000)
- # define COMPILER_VERSION_MINOR DEC(__VERSION__ % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__VERSION__)
-
-#elif defined(__ORANGEC__)
-# define COMPILER_ID "OrangeC"
-# define COMPILER_VERSION_MAJOR DEC(__ORANGEC_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__ORANGEC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__ORANGEC_PATCHLEVEL__)
-
-#elif defined(__SCO_VERSION__)
-# define COMPILER_ID "SCO"
-
-#elif defined(__ARMCC_VERSION) && !defined(__clang__)
-# define COMPILER_ID "ARMCC"
-#if __ARMCC_VERSION >= 1000000
- /* __ARMCC_VERSION = VRRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#else
- /* __ARMCC_VERSION = VRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#endif
-
-
-#elif defined(__clang__) && defined(__apple_build_version__)
-# define COMPILER_ID "AppleClang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__)
-
-#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION)
-# define COMPILER_ID "ARMClang"
- # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION/100 % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION)
-
-#elif defined(__clang__) && defined(__ti__)
-# define COMPILER_ID "TIClang"
- # define COMPILER_VERSION_MAJOR DEC(__ti_major__)
- # define COMPILER_VERSION_MINOR DEC(__ti_minor__)
- # define COMPILER_VERSION_PATCH DEC(__ti_patchlevel__)
-# define COMPILER_VERSION_INTERNAL DEC(__ti_version__)
-
-#elif defined(__clang__)
-# define COMPILER_ID "Clang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-
-#elif defined(__LCC__) && (defined(__GNUC__) || defined(__GNUG__) || defined(__MCST__))
-# define COMPILER_ID "LCC"
-# define COMPILER_VERSION_MAJOR DEC(__LCC__ / 100)
-# define COMPILER_VERSION_MINOR DEC(__LCC__ % 100)
-# if defined(__LCC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__LCC_MINOR__)
-# endif
-# if defined(__GNUC__) && defined(__GNUC_MINOR__)
-# define SIMULATE_ID "GNU"
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-# endif
-
-#elif defined(__GNUC__) || defined(__GNUG__)
-# define COMPILER_ID "GNU"
-# if defined(__GNUC__)
-# define COMPILER_VERSION_MAJOR DEC(__GNUC__)
-# else
-# define COMPILER_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif defined(_MSC_VER)
-# define COMPILER_ID "MSVC"
- /* _MSC_VER = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100)
-# if defined(_MSC_FULL_VER)
-# if _MSC_VER >= 1400
- /* _MSC_FULL_VER = VVRRPPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000)
-# else
- /* _MSC_FULL_VER = VVRRPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000)
-# endif
-# endif
-# if defined(_MSC_BUILD)
-# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD)
-# endif
-
-#elif defined(_ADI_COMPILER)
-# define COMPILER_ID "ADSP"
-#if defined(__VERSIONNUM__)
- /* __VERSIONNUM__ = 0xVVRRPPTT */
-# define COMPILER_VERSION_MAJOR DEC(__VERSIONNUM__ >> 24 & 0xFF)
-# define COMPILER_VERSION_MINOR DEC(__VERSIONNUM__ >> 16 & 0xFF)
-# define COMPILER_VERSION_PATCH DEC(__VERSIONNUM__ >> 8 & 0xFF)
-# define COMPILER_VERSION_TWEAK DEC(__VERSIONNUM__ & 0xFF)
-#endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# define COMPILER_ID "IAR"
-# if defined(__VER__) && defined(__ICCARM__)
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000)
-# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000)
-# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__) || defined(__ICCSTM8__))
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100)
-# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100))
-# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# endif
-
-
-/* These compilers are either not known or too old to define an
- identification macro. Try to identify the platform and guess that
- it is the native compiler. */
-#elif defined(__hpux) || defined(__hpua)
-# define COMPILER_ID "HP"
-
-#else /* unknown compiler */
-# define COMPILER_ID ""
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]";
-#ifdef SIMULATE_ID
-char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]";
-#endif
-
-#ifdef __QNXNTO__
-char const* qnxnto = "INFO" ":" "qnxnto[]";
-#endif
-
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
-char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]";
-#endif
-
-#define STRINGIFY_HELPER(X) #X
-#define STRINGIFY(X) STRINGIFY_HELPER(X)
-
-/* Identify known platforms by name. */
-#if defined(__linux) || defined(__linux__) || defined(linux)
-# define PLATFORM_ID "Linux"
-
-#elif defined(__MSYS__)
-# define PLATFORM_ID "MSYS"
-
-#elif defined(__CYGWIN__)
-# define PLATFORM_ID "Cygwin"
-
-#elif defined(__MINGW32__)
-# define PLATFORM_ID "MinGW"
-
-#elif defined(__APPLE__)
-# define PLATFORM_ID "Darwin"
-
-#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
-# define PLATFORM_ID "Windows"
-
-#elif defined(__FreeBSD__) || defined(__FreeBSD)
-# define PLATFORM_ID "FreeBSD"
-
-#elif defined(__NetBSD__) || defined(__NetBSD)
-# define PLATFORM_ID "NetBSD"
-
-#elif defined(__OpenBSD__) || defined(__OPENBSD)
-# define PLATFORM_ID "OpenBSD"
-
-#elif defined(__sun) || defined(sun)
-# define PLATFORM_ID "SunOS"
-
-#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__)
-# define PLATFORM_ID "AIX"
-
-#elif defined(__hpux) || defined(__hpux__)
-# define PLATFORM_ID "HP-UX"
-
-#elif defined(__HAIKU__)
-# define PLATFORM_ID "Haiku"
-
-#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS)
-# define PLATFORM_ID "BeOS"
-
-#elif defined(__QNX__) || defined(__QNXNTO__)
-# define PLATFORM_ID "QNX"
-
-#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__)
-# define PLATFORM_ID "Tru64"
-
-#elif defined(__riscos) || defined(__riscos__)
-# define PLATFORM_ID "RISCos"
-
-#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__)
-# define PLATFORM_ID "SINIX"
-
-#elif defined(__UNIX_SV__)
-# define PLATFORM_ID "UNIX_SV"
-
-#elif defined(__bsdos__)
-# define PLATFORM_ID "BSDOS"
-
-#elif defined(_MPRAS) || defined(MPRAS)
-# define PLATFORM_ID "MP-RAS"
-
-#elif defined(__osf) || defined(__osf__)
-# define PLATFORM_ID "OSF1"
-
-#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv)
-# define PLATFORM_ID "SCO_SV"
-
-#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX)
-# define PLATFORM_ID "ULTRIX"
-
-#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX)
-# define PLATFORM_ID "Xenix"
-
-#elif defined(__WATCOMC__)
-# if defined(__LINUX__)
-# define PLATFORM_ID "Linux"
-
-# elif defined(__DOS__)
-# define PLATFORM_ID "DOS"
-
-# elif defined(__OS2__)
-# define PLATFORM_ID "OS2"
-
-# elif defined(__WINDOWS__)
-# define PLATFORM_ID "Windows3x"
-
-# elif defined(__VXWORKS__)
-# define PLATFORM_ID "VxWorks"
-
-# else /* unknown platform */
-# define PLATFORM_ID
-# endif
-
-#elif defined(__INTEGRITY)
-# if defined(INT_178B)
-# define PLATFORM_ID "Integrity178"
-
-# else /* regular Integrity */
-# define PLATFORM_ID "Integrity"
-# endif
-
-# elif defined(_ADI_COMPILER)
-# define PLATFORM_ID "ADSP"
-
-#else /* unknown platform */
-# define PLATFORM_ID
-
-#endif
-
-/* For windows compilers MSVC and Intel we can determine
- the architecture of the compiler being used. This is because
- the compilers do not have flags that can change the architecture,
- but rather depend on which compiler is being used
-*/
-#if defined(_WIN32) && defined(_MSC_VER)
-# if defined(_M_IA64)
-# define ARCHITECTURE_ID "IA64"
-
-# elif defined(_M_ARM64EC)
-# define ARCHITECTURE_ID "ARM64EC"
-
-# elif defined(_M_X64) || defined(_M_AMD64)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# elif defined(_M_ARM64)
-# define ARCHITECTURE_ID "ARM64"
-
-# elif defined(_M_ARM)
-# if _M_ARM == 4
-# define ARCHITECTURE_ID "ARMV4I"
-# elif _M_ARM == 5
-# define ARCHITECTURE_ID "ARMV5I"
-# else
-# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM)
-# endif
-
-# elif defined(_M_MIPS)
-# define ARCHITECTURE_ID "MIPS"
-
-# elif defined(_M_SH)
-# define ARCHITECTURE_ID "SHx"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__WATCOMC__)
-# if defined(_M_I86)
-# define ARCHITECTURE_ID "I86"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# if defined(__ICCARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__ICCRX__)
-# define ARCHITECTURE_ID "RX"
-
-# elif defined(__ICCRH850__)
-# define ARCHITECTURE_ID "RH850"
-
-# elif defined(__ICCRL78__)
-# define ARCHITECTURE_ID "RL78"
-
-# elif defined(__ICCRISCV__)
-# define ARCHITECTURE_ID "RISCV"
-
-# elif defined(__ICCAVR__)
-# define ARCHITECTURE_ID "AVR"
-
-# elif defined(__ICC430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__ICCV850__)
-# define ARCHITECTURE_ID "V850"
-
-# elif defined(__ICC8051__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__ICCSTM8__)
-# define ARCHITECTURE_ID "STM8"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__ghs__)
-# if defined(__PPC64__)
-# define ARCHITECTURE_ID "PPC64"
-
-# elif defined(__ppc__)
-# define ARCHITECTURE_ID "PPC"
-
-# elif defined(__ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__x86_64__)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(__i386__)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__clang__) && defined(__ti__)
-# if defined(__ARM_ARCH)
-# define ARCHITECTURE_ID "Arm"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__TI_COMPILER_VERSION__)
-# if defined(__TI_ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__MSP430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__TMS320C28XX__)
-# define ARCHITECTURE_ID "TMS320C28x"
-
-# elif defined(__TMS320C6X__) || defined(_TMS320C6X)
-# define ARCHITECTURE_ID "TMS320C6x"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-# elif defined(__ADSPSHARC__)
-# define ARCHITECTURE_ID "SHARC"
-
-# elif defined(__ADSPBLACKFIN__)
-# define ARCHITECTURE_ID "Blackfin"
-
-#elif defined(__TASKING__)
-
-# if defined(__CTC__) || defined(__CPTC__)
-# define ARCHITECTURE_ID "TriCore"
-
-# elif defined(__CMCS__)
-# define ARCHITECTURE_ID "MCS"
-
-# elif defined(__CARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__CARC__)
-# define ARCHITECTURE_ID "ARC"
-
-# elif defined(__C51__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__CPCP__)
-# define ARCHITECTURE_ID "PCP"
-
-# else
-# define ARCHITECTURE_ID ""
-# endif
-
-#else
-# define ARCHITECTURE_ID
-#endif
-
-/* Convert integer to decimal digit literals. */
-#define DEC(n) \
- ('0' + (((n) / 10000000)%10)), \
- ('0' + (((n) / 1000000)%10)), \
- ('0' + (((n) / 100000)%10)), \
- ('0' + (((n) / 10000)%10)), \
- ('0' + (((n) / 1000)%10)), \
- ('0' + (((n) / 100)%10)), \
- ('0' + (((n) / 10)%10)), \
- ('0' + ((n) % 10))
-
-/* Convert integer to hex digit literals. */
-#define HEX(n) \
- ('0' + ((n)>>28 & 0xF)), \
- ('0' + ((n)>>24 & 0xF)), \
- ('0' + ((n)>>20 & 0xF)), \
- ('0' + ((n)>>16 & 0xF)), \
- ('0' + ((n)>>12 & 0xF)), \
- ('0' + ((n)>>8 & 0xF)), \
- ('0' + ((n)>>4 & 0xF)), \
- ('0' + ((n) & 0xF))
-
-/* Construct a string literal encoding the version number. */
-#ifdef COMPILER_VERSION
-char const* info_version = "INFO" ":" "compiler_version[" COMPILER_VERSION "]";
-
-/* Construct a string literal encoding the version number components. */
-#elif defined(COMPILER_VERSION_MAJOR)
-char const info_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[',
- COMPILER_VERSION_MAJOR,
-# ifdef COMPILER_VERSION_MINOR
- '.', COMPILER_VERSION_MINOR,
-# ifdef COMPILER_VERSION_PATCH
- '.', COMPILER_VERSION_PATCH,
-# ifdef COMPILER_VERSION_TWEAK
- '.', COMPILER_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct a string literal encoding the internal version number. */
-#ifdef COMPILER_VERSION_INTERNAL
-char const info_version_internal[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_',
- 'i','n','t','e','r','n','a','l','[',
- COMPILER_VERSION_INTERNAL,']','\0'};
-#elif defined(COMPILER_VERSION_INTERNAL_STR)
-char const* info_version_internal = "INFO" ":" "compiler_version_internal[" COMPILER_VERSION_INTERNAL_STR "]";
-#endif
-
-/* Construct a string literal encoding the version number components. */
-#ifdef SIMULATE_VERSION_MAJOR
-char const info_simulate_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[',
- SIMULATE_VERSION_MAJOR,
-# ifdef SIMULATE_VERSION_MINOR
- '.', SIMULATE_VERSION_MINOR,
-# ifdef SIMULATE_VERSION_PATCH
- '.', SIMULATE_VERSION_PATCH,
-# ifdef SIMULATE_VERSION_TWEAK
- '.', SIMULATE_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]";
-char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]";
-
-
-
-#define CXX_STD_98 199711L
-#define CXX_STD_11 201103L
-#define CXX_STD_14 201402L
-#define CXX_STD_17 201703L
-#define CXX_STD_20 202002L
-#define CXX_STD_23 202302L
-
-#if defined(__INTEL_COMPILER) && defined(_MSVC_LANG)
-# if _MSVC_LANG > CXX_STD_17
-# define CXX_STD _MSVC_LANG
-# elif _MSVC_LANG == CXX_STD_17 && defined(__cpp_aggregate_paren_init)
-# define CXX_STD CXX_STD_20
-# elif _MSVC_LANG > CXX_STD_14 && __cplusplus > CXX_STD_17
-# define CXX_STD CXX_STD_20
-# elif _MSVC_LANG > CXX_STD_14
-# define CXX_STD CXX_STD_17
-# elif defined(__INTEL_CXX11_MODE__) && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# elif defined(__INTEL_CXX11_MODE__)
-# define CXX_STD CXX_STD_11
-# else
-# define CXX_STD CXX_STD_98
-# endif
-#elif defined(_MSC_VER) && defined(_MSVC_LANG)
-# if _MSVC_LANG > __cplusplus
-# define CXX_STD _MSVC_LANG
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif defined(__NVCOMPILER)
-# if __cplusplus == CXX_STD_17 && defined(__cpp_aggregate_paren_init)
-# define CXX_STD CXX_STD_20
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif defined(__INTEL_COMPILER) || defined(__PGI)
-# if __cplusplus == CXX_STD_11 && defined(__cpp_namespace_attributes)
-# define CXX_STD CXX_STD_17
-# elif __cplusplus == CXX_STD_11 && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif (defined(__IBMCPP__) || defined(__ibmxl__)) && defined(__linux__)
-# if __cplusplus == CXX_STD_11 && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif __cplusplus == 1 && defined(__GXX_EXPERIMENTAL_CXX0X__)
-# define CXX_STD CXX_STD_11
-#else
-# define CXX_STD __cplusplus
-#endif
-
-const char* info_language_standard_default = "INFO" ":" "standard_default["
-#if CXX_STD > CXX_STD_23
- "26"
-#elif CXX_STD > CXX_STD_20
- "23"
-#elif CXX_STD > CXX_STD_17
- "20"
-#elif CXX_STD > CXX_STD_14
- "17"
-#elif CXX_STD > CXX_STD_11
- "14"
-#elif CXX_STD >= CXX_STD_11
- "11"
-#else
- "98"
-#endif
-"]";
-
-const char* info_language_extensions_default = "INFO" ":" "extensions_default["
-#if (defined(__clang__) || defined(__GNUC__) || defined(__xlC__) || \
- defined(__TI_COMPILER_VERSION__)) && \
- !defined(__STRICT_ANSI__)
- "ON"
-#else
- "OFF"
-#endif
-"]";
-
-/*--------------------------------------------------------------------------*/
-
-int main(int argc, char* argv[])
-{
- int require = 0;
- require += info_compiler[argc];
- require += info_platform[argc];
- require += info_arch[argc];
-#ifdef COMPILER_VERSION_MAJOR
- require += info_version[argc];
-#endif
-#ifdef COMPILER_VERSION_INTERNAL
- require += info_version_internal[argc];
-#endif
-#ifdef SIMULATE_ID
- require += info_simulate[argc];
-#endif
-#ifdef SIMULATE_VERSION_MAJOR
- require += info_simulate_version[argc];
-#endif
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
- require += info_cray[argc];
-#endif
- require += info_language_standard_default[argc];
- require += info_language_extensions_default[argc];
- (void)argv;
- return require;
-}
diff --git a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/a.exe b/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/a.exe
deleted file mode 100644
index 34935fe..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/3.30.5/CompilerIdCXX/a.exe and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCCompiler.cmake
deleted file mode 100644
index 67ad797..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCCompiler.cmake
+++ /dev/null
@@ -1,84 +0,0 @@
-set(CMAKE_C_COMPILER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe")
-set(CMAKE_C_COMPILER_ARG1 "")
-set(CMAKE_C_COMPILER_ID "GNU")
-set(CMAKE_C_COMPILER_VERSION "13.1.0")
-set(CMAKE_C_COMPILER_VERSION_INTERNAL "")
-set(CMAKE_C_COMPILER_WRAPPER "")
-set(CMAKE_C_STANDARD_COMPUTED_DEFAULT "17")
-set(CMAKE_C_EXTENSIONS_COMPUTED_DEFAULT "ON")
-set(CMAKE_C_STANDARD_LATEST "23")
-set(CMAKE_C_COMPILE_FEATURES "c_std_90;c_function_prototypes;c_std_99;c_restrict;c_variadic_macros;c_std_11;c_static_assert;c_std_17;c_std_23")
-set(CMAKE_C90_COMPILE_FEATURES "c_std_90;c_function_prototypes")
-set(CMAKE_C99_COMPILE_FEATURES "c_std_99;c_restrict;c_variadic_macros")
-set(CMAKE_C11_COMPILE_FEATURES "c_std_11;c_static_assert")
-set(CMAKE_C17_COMPILE_FEATURES "c_std_17")
-set(CMAKE_C23_COMPILE_FEATURES "c_std_23")
-
-set(CMAKE_C_PLATFORM_ID "MinGW")
-set(CMAKE_C_SIMULATE_ID "")
-set(CMAKE_C_COMPILER_FRONTEND_VARIANT "GNU")
-set(CMAKE_C_COMPILER_APPLE_SYSROOT "")
-set(CMAKE_C_SIMULATE_VERSION "")
-
-
-
-
-set(CMAKE_AR "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe")
-set(CMAKE_C_COMPILER_AR "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe")
-set(CMAKE_RANLIB "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe")
-set(CMAKE_C_COMPILER_RANLIB "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe")
-set(CMAKE_LINKER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_LINKER_LINK "")
-set(CMAKE_LINKER_LLD "")
-set(CMAKE_C_COMPILER_LINKER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_C_COMPILER_LINKER_ID "GNU")
-set(CMAKE_C_COMPILER_LINKER_VERSION 2.40)
-set(CMAKE_C_COMPILER_LINKER_FRONTEND_VARIANT GNU)
-set(CMAKE_MT "")
-set(CMAKE_TAPI "CMAKE_TAPI-NOTFOUND")
-set(CMAKE_COMPILER_IS_GNUCC 1)
-set(CMAKE_C_COMPILER_LOADED 1)
-set(CMAKE_C_COMPILER_WORKS TRUE)
-set(CMAKE_C_ABI_COMPILED TRUE)
-
-set(CMAKE_C_COMPILER_ENV_VAR "CC")
-
-set(CMAKE_C_COMPILER_ID_RUN 1)
-set(CMAKE_C_SOURCE_FILE_EXTENSIONS c;m)
-set(CMAKE_C_IGNORE_EXTENSIONS h;H;o;O;obj;OBJ;def;DEF;rc;RC)
-set(CMAKE_C_LINKER_PREFERENCE 10)
-set(CMAKE_C_LINKER_DEPFILE_SUPPORTED FALSE)
-set(CMAKE_LINKER_PUSHPOP_STATE_SUPPORTED TRUE)
-set(CMAKE_C_LINKER_PUSHPOP_STATE_SUPPORTED TRUE)
-
-# Save compiler ABI information.
-set(CMAKE_C_SIZEOF_DATA_PTR "8")
-set(CMAKE_C_COMPILER_ABI "")
-set(CMAKE_C_BYTE_ORDER "LITTLE_ENDIAN")
-set(CMAKE_C_LIBRARY_ARCHITECTURE "")
-
-if(CMAKE_C_SIZEOF_DATA_PTR)
- set(CMAKE_SIZEOF_VOID_P "${CMAKE_C_SIZEOF_DATA_PTR}")
-endif()
-
-if(CMAKE_C_COMPILER_ABI)
- set(CMAKE_INTERNAL_PLATFORM_ABI "${CMAKE_C_COMPILER_ABI}")
-endif()
-
-if(CMAKE_C_LIBRARY_ARCHITECTURE)
- set(CMAKE_LIBRARY_ARCHITECTURE "")
-endif()
-
-set(CMAKE_C_CL_SHOWINCLUDES_PREFIX "")
-if(CMAKE_C_CL_SHOWINCLUDES_PREFIX)
- set(CMAKE_CL_SHOWINCLUDES_PREFIX "${CMAKE_C_CL_SHOWINCLUDES_PREFIX}")
-endif()
-
-
-
-
-
-set(CMAKE_C_IMPLICIT_INCLUDE_DIRECTORIES "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include")
-set(CMAKE_C_IMPLICIT_LINK_LIBRARIES "mingw32;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc;moldname;mingwex;kernel32")
-set(CMAKE_C_IMPLICIT_LINK_DIRECTORIES "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib")
-set(CMAKE_C_IMPLICIT_LINK_FRAMEWORK_DIRECTORIES "")
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCXXCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCXXCompiler.cmake
deleted file mode 100644
index 03375fd..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeCXXCompiler.cmake
+++ /dev/null
@@ -1,104 +0,0 @@
-set(CMAKE_CXX_COMPILER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe")
-set(CMAKE_CXX_COMPILER_ARG1 "")
-set(CMAKE_CXX_COMPILER_ID "GNU")
-set(CMAKE_CXX_COMPILER_VERSION "13.1.0")
-set(CMAKE_CXX_COMPILER_VERSION_INTERNAL "")
-set(CMAKE_CXX_COMPILER_WRAPPER "")
-set(CMAKE_CXX_STANDARD_COMPUTED_DEFAULT "17")
-set(CMAKE_CXX_EXTENSIONS_COMPUTED_DEFAULT "ON")
-set(CMAKE_CXX_STANDARD_LATEST "23")
-set(CMAKE_CXX_COMPILE_FEATURES "cxx_std_98;cxx_template_template_parameters;cxx_std_11;cxx_alias_templates;cxx_alignas;cxx_alignof;cxx_attributes;cxx_auto_type;cxx_constexpr;cxx_decltype;cxx_decltype_incomplete_return_types;cxx_default_function_template_args;cxx_defaulted_functions;cxx_defaulted_move_initializers;cxx_delegating_constructors;cxx_deleted_functions;cxx_enum_forward_declarations;cxx_explicit_conversions;cxx_extended_friend_declarations;cxx_extern_templates;cxx_final;cxx_func_identifier;cxx_generalized_initializers;cxx_inheriting_constructors;cxx_inline_namespaces;cxx_lambdas;cxx_local_type_template_args;cxx_long_long_type;cxx_noexcept;cxx_nonstatic_member_init;cxx_nullptr;cxx_override;cxx_range_for;cxx_raw_string_literals;cxx_reference_qualified_functions;cxx_right_angle_brackets;cxx_rvalue_references;cxx_sizeof_member;cxx_static_assert;cxx_strong_enums;cxx_thread_local;cxx_trailing_return_types;cxx_unicode_literals;cxx_uniform_initialization;cxx_unrestricted_unions;cxx_user_literals;cxx_variadic_macros;cxx_variadic_templates;cxx_std_14;cxx_aggregate_default_initializers;cxx_attribute_deprecated;cxx_binary_literals;cxx_contextual_conversions;cxx_decltype_auto;cxx_digit_separators;cxx_generic_lambdas;cxx_lambda_init_captures;cxx_relaxed_constexpr;cxx_return_type_deduction;cxx_variable_templates;cxx_std_17;cxx_std_20;cxx_std_23")
-set(CMAKE_CXX98_COMPILE_FEATURES "cxx_std_98;cxx_template_template_parameters")
-set(CMAKE_CXX11_COMPILE_FEATURES "cxx_std_11;cxx_alias_templates;cxx_alignas;cxx_alignof;cxx_attributes;cxx_auto_type;cxx_constexpr;cxx_decltype;cxx_decltype_incomplete_return_types;cxx_default_function_template_args;cxx_defaulted_functions;cxx_defaulted_move_initializers;cxx_delegating_constructors;cxx_deleted_functions;cxx_enum_forward_declarations;cxx_explicit_conversions;cxx_extended_friend_declarations;cxx_extern_templates;cxx_final;cxx_func_identifier;cxx_generalized_initializers;cxx_inheriting_constructors;cxx_inline_namespaces;cxx_lambdas;cxx_local_type_template_args;cxx_long_long_type;cxx_noexcept;cxx_nonstatic_member_init;cxx_nullptr;cxx_override;cxx_range_for;cxx_raw_string_literals;cxx_reference_qualified_functions;cxx_right_angle_brackets;cxx_rvalue_references;cxx_sizeof_member;cxx_static_assert;cxx_strong_enums;cxx_thread_local;cxx_trailing_return_types;cxx_unicode_literals;cxx_uniform_initialization;cxx_unrestricted_unions;cxx_user_literals;cxx_variadic_macros;cxx_variadic_templates")
-set(CMAKE_CXX14_COMPILE_FEATURES "cxx_std_14;cxx_aggregate_default_initializers;cxx_attribute_deprecated;cxx_binary_literals;cxx_contextual_conversions;cxx_decltype_auto;cxx_digit_separators;cxx_generic_lambdas;cxx_lambda_init_captures;cxx_relaxed_constexpr;cxx_return_type_deduction;cxx_variable_templates")
-set(CMAKE_CXX17_COMPILE_FEATURES "cxx_std_17")
-set(CMAKE_CXX20_COMPILE_FEATURES "cxx_std_20")
-set(CMAKE_CXX23_COMPILE_FEATURES "cxx_std_23")
-set(CMAKE_CXX26_COMPILE_FEATURES "")
-
-set(CMAKE_CXX_PLATFORM_ID "MinGW")
-set(CMAKE_CXX_SIMULATE_ID "")
-set(CMAKE_CXX_COMPILER_FRONTEND_VARIANT "GNU")
-set(CMAKE_CXX_COMPILER_APPLE_SYSROOT "")
-set(CMAKE_CXX_SIMULATE_VERSION "")
-
-
-
-
-set(CMAKE_AR "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ar.exe")
-set(CMAKE_CXX_COMPILER_AR "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ar.exe")
-set(CMAKE_RANLIB "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ranlib.exe")
-set(CMAKE_CXX_COMPILER_RANLIB "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc-ranlib.exe")
-set(CMAKE_LINKER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_LINKER_LINK "")
-set(CMAKE_LINKER_LLD "")
-set(CMAKE_CXX_COMPILER_LINKER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe")
-set(CMAKE_CXX_COMPILER_LINKER_ID "GNU")
-set(CMAKE_CXX_COMPILER_LINKER_VERSION 2.40)
-set(CMAKE_CXX_COMPILER_LINKER_FRONTEND_VARIANT GNU)
-set(CMAKE_MT "")
-set(CMAKE_TAPI "CMAKE_TAPI-NOTFOUND")
-set(CMAKE_COMPILER_IS_GNUCXX 1)
-set(CMAKE_CXX_COMPILER_LOADED 1)
-set(CMAKE_CXX_COMPILER_WORKS TRUE)
-set(CMAKE_CXX_ABI_COMPILED TRUE)
-
-set(CMAKE_CXX_COMPILER_ENV_VAR "CXX")
-
-set(CMAKE_CXX_COMPILER_ID_RUN 1)
-set(CMAKE_CXX_SOURCE_FILE_EXTENSIONS C;M;c++;cc;cpp;cxx;m;mm;mpp;CPP;ixx;cppm;ccm;cxxm;c++m)
-set(CMAKE_CXX_IGNORE_EXTENSIONS inl;h;hpp;HPP;H;o;O;obj;OBJ;def;DEF;rc;RC)
-
-foreach (lang IN ITEMS C OBJC OBJCXX)
- if (CMAKE_${lang}_COMPILER_ID_RUN)
- foreach(extension IN LISTS CMAKE_${lang}_SOURCE_FILE_EXTENSIONS)
- list(REMOVE_ITEM CMAKE_CXX_SOURCE_FILE_EXTENSIONS ${extension})
- endforeach()
- endif()
-endforeach()
-
-set(CMAKE_CXX_LINKER_PREFERENCE 30)
-set(CMAKE_CXX_LINKER_PREFERENCE_PROPAGATES 1)
-set(CMAKE_CXX_LINKER_DEPFILE_SUPPORTED FALSE)
-set(CMAKE_LINKER_PUSHPOP_STATE_SUPPORTED TRUE)
-set(CMAKE_CXX_LINKER_PUSHPOP_STATE_SUPPORTED TRUE)
-
-# Save compiler ABI information.
-set(CMAKE_CXX_SIZEOF_DATA_PTR "8")
-set(CMAKE_CXX_COMPILER_ABI "")
-set(CMAKE_CXX_BYTE_ORDER "LITTLE_ENDIAN")
-set(CMAKE_CXX_LIBRARY_ARCHITECTURE "")
-
-if(CMAKE_CXX_SIZEOF_DATA_PTR)
- set(CMAKE_SIZEOF_VOID_P "${CMAKE_CXX_SIZEOF_DATA_PTR}")
-endif()
-
-if(CMAKE_CXX_COMPILER_ABI)
- set(CMAKE_INTERNAL_PLATFORM_ABI "${CMAKE_CXX_COMPILER_ABI}")
-endif()
-
-if(CMAKE_CXX_LIBRARY_ARCHITECTURE)
- set(CMAKE_LIBRARY_ARCHITECTURE "")
-endif()
-
-set(CMAKE_CXX_CL_SHOWINCLUDES_PREFIX "")
-if(CMAKE_CXX_CL_SHOWINCLUDES_PREFIX)
- set(CMAKE_CL_SHOWINCLUDES_PREFIX "${CMAKE_CXX_CL_SHOWINCLUDES_PREFIX}")
-endif()
-
-
-
-
-
-set(CMAKE_CXX_IMPLICIT_INCLUDE_DIRECTORIES "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include")
-set(CMAKE_CXX_IMPLICIT_LINK_LIBRARIES "stdc++;mingw32;gcc_s;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc_s;gcc;moldname;mingwex;kernel32")
-set(CMAKE_CXX_IMPLICIT_LINK_DIRECTORIES "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib")
-set(CMAKE_CXX_IMPLICIT_LINK_FRAMEWORK_DIRECTORIES "")
-set(CMAKE_CXX_COMPILER_CLANG_RESOURCE_DIR "")
-
-set(CMAKE_CXX_COMPILER_IMPORT_STD "")
-### Imported target for C++23 standard library
-set(CMAKE_CXX23_COMPILER_IMPORT_STD_NOT_FOUND_MESSAGE "Experimental `import std` support not enabled when detecting toolchain; it must be set before `CXX` is enabled (usually a `project()` call)")
-
-
-
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_C.bin b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_C.bin
deleted file mode 100644
index f6fa40a..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_C.bin and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_CXX.bin b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_CXX.bin
deleted file mode 100644
index 343ec28..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeDetermineCompilerABI_CXX.bin and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeRCCompiler.cmake b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeRCCompiler.cmake
deleted file mode 100644
index 6e6eee2..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeRCCompiler.cmake
+++ /dev/null
@@ -1,6 +0,0 @@
-set(CMAKE_RC_COMPILER "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/windres.exe")
-set(CMAKE_RC_COMPILER_ARG1 "")
-set(CMAKE_RC_COMPILER_LOADED 1)
-set(CMAKE_RC_SOURCE_FILE_EXTENSIONS rc;RC)
-set(CMAKE_RC_OUTPUT_EXTENSION .obj)
-set(CMAKE_RC_COMPILER_ENV_VAR "RC")
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeSystem.cmake b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeSystem.cmake
deleted file mode 100644
index 000cf69..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CMakeSystem.cmake
+++ /dev/null
@@ -1,15 +0,0 @@
-set(CMAKE_HOST_SYSTEM "Windows-10.0.26100")
-set(CMAKE_HOST_SYSTEM_NAME "Windows")
-set(CMAKE_HOST_SYSTEM_VERSION "10.0.26100")
-set(CMAKE_HOST_SYSTEM_PROCESSOR "AMD64")
-
-
-
-set(CMAKE_SYSTEM "Windows-10.0.26100")
-set(CMAKE_SYSTEM_NAME "Windows")
-set(CMAKE_SYSTEM_VERSION "10.0.26100")
-set(CMAKE_SYSTEM_PROCESSOR "AMD64")
-
-set(CMAKE_CROSSCOMPILING "FALSE")
-
-set(CMAKE_SYSTEM_LOADED 1)
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/CMakeCCompilerId.c b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/CMakeCCompilerId.c
deleted file mode 100644
index a842bb6..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/CMakeCCompilerId.c
+++ /dev/null
@@ -1,905 +0,0 @@
-#ifdef __cplusplus
-# error "A C++ compiler has been selected for C."
-#endif
-
-#if defined(__18CXX)
-# define ID_VOID_MAIN
-#endif
-#if defined(__CLASSIC_C__)
-/* cv-qualifiers did not exist in K&R C */
-# define const
-# define volatile
-#endif
-
-#if !defined(__has_include)
-/* If the compiler does not have __has_include, pretend the answer is
- always no. */
-# define __has_include(x) 0
-#endif
-
-
-/* Version number components: V=Version, R=Revision, P=Patch
- Version date components: YYYY=Year, MM=Month, DD=Day */
-
-#if defined(__INTEL_COMPILER) || defined(__ICC)
-# define COMPILER_ID "Intel"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-# endif
- /* __INTEL_COMPILER = VRP prior to 2021, and then VVVV for 2021 and later,
- except that a few beta releases use the old format with V=2021. */
-# if __INTEL_COMPILER < 2021 || __INTEL_COMPILER == 202110 || __INTEL_COMPILER == 202111
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10)
-# if defined(__INTEL_COMPILER_UPDATE)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE)
-# else
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10)
-# endif
-# else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER_UPDATE)
- /* The third version component from --version is an update index,
- but no macro is provided for it. */
-# define COMPILER_VERSION_PATCH DEC(0)
-# endif
-# if defined(__INTEL_COMPILER_BUILD_DATE)
- /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */
-# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE)
-# endif
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif (defined(__clang__) && defined(__INTEL_CLANG_COMPILER)) || defined(__INTEL_LLVM_COMPILER)
-# define COMPILER_ID "IntelLLVM"
-#if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-#endif
-/* __INTEL_LLVM_COMPILER = VVVVRP prior to 2021.2.0, VVVVRRPP for 2021.2.0 and
- * later. Look for 6 digit vs. 8 digit version number to decide encoding.
- * VVVV is no smaller than the current year when a version is released.
- */
-#if __INTEL_LLVM_COMPILER < 1000000L
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 10)
-#else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/10000)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 100)
-#endif
-#if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-#elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-#endif
-#if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-#endif
-#if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-#endif
-
-#elif defined(__PATHCC__)
-# define COMPILER_ID "PathScale"
-# define COMPILER_VERSION_MAJOR DEC(__PATHCC__)
-# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__)
-# if defined(__PATHCC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__)
-# endif
-
-#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__)
-# define COMPILER_ID "Embarcadero"
-# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF)
-# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF)
-# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF)
-
-#elif defined(__BORLANDC__)
-# define COMPILER_ID "Borland"
- /* __BORLANDC__ = 0xVRR */
-# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8)
-# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF)
-
-#elif defined(__WATCOMC__) && __WATCOMC__ < 1200
-# define COMPILER_ID "Watcom"
- /* __WATCOMC__ = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__WATCOMC__)
-# define COMPILER_ID "OpenWatcom"
- /* __WATCOMC__ = VVRP + 1100 */
-# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__SUNPRO_C)
-# define COMPILER_ID "SunPro"
-# if __SUNPRO_C >= 0x5100
- /* __SUNPRO_C = 0xVRRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>12)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xFF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
-# else
- /* __SUNPRO_CC = 0xVRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_C>>8)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_C>>4 & 0xF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_C & 0xF)
-# endif
-
-#elif defined(__HP_cc)
-# define COMPILER_ID "HP"
- /* __HP_cc = VVRRPP */
-# define COMPILER_VERSION_MAJOR DEC(__HP_cc/10000)
-# define COMPILER_VERSION_MINOR DEC(__HP_cc/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__HP_cc % 100)
-
-#elif defined(__DECC)
-# define COMPILER_ID "Compaq"
- /* __DECC_VER = VVRRTPPPP */
-# define COMPILER_VERSION_MAJOR DEC(__DECC_VER/10000000)
-# define COMPILER_VERSION_MINOR DEC(__DECC_VER/100000 % 100)
-# define COMPILER_VERSION_PATCH DEC(__DECC_VER % 10000)
-
-#elif defined(__IBMC__) && defined(__COMPILER_VER__)
-# define COMPILER_ID "zOS"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__open_xl__) && defined(__clang__)
-# define COMPILER_ID "IBMClang"
-# define COMPILER_VERSION_MAJOR DEC(__open_xl_version__)
-# define COMPILER_VERSION_MINOR DEC(__open_xl_release__)
-# define COMPILER_VERSION_PATCH DEC(__open_xl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__open_xl_ptf_fix_level__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__ibmxl__) && defined(__clang__)
-# define COMPILER_ID "XLClang"
-# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__)
-# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__)
-# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__)
-
-
-#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ >= 800
-# define COMPILER_ID "XL"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__IBMC__) && !defined(__COMPILER_VER__) && __IBMC__ < 800
-# define COMPILER_ID "VisualAge"
- /* __IBMC__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMC__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMC__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMC__ % 10)
-
-#elif defined(__NVCOMPILER)
-# define COMPILER_ID "NVHPC"
-# define COMPILER_VERSION_MAJOR DEC(__NVCOMPILER_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__NVCOMPILER_MINOR__)
-# if defined(__NVCOMPILER_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__NVCOMPILER_PATCHLEVEL__)
-# endif
-
-#elif defined(__PGI)
-# define COMPILER_ID "PGI"
-# define COMPILER_VERSION_MAJOR DEC(__PGIC__)
-# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__)
-# if defined(__PGIC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__)
-# endif
-
-#elif defined(__clang__) && defined(__cray__)
-# define COMPILER_ID "CrayClang"
-# define COMPILER_VERSION_MAJOR DEC(__cray_major__)
-# define COMPILER_VERSION_MINOR DEC(__cray_minor__)
-# define COMPILER_VERSION_PATCH DEC(__cray_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(_CRAYC)
-# define COMPILER_ID "Cray"
-# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR)
-
-#elif defined(__TI_COMPILER_VERSION__)
-# define COMPILER_ID "TI"
- /* __TI_COMPILER_VERSION__ = VVVRRRPPP */
-# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000)
-# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000)
-# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000)
-
-#elif defined(__CLANG_FUJITSU)
-# define COMPILER_ID "FujitsuClang"
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__FUJITSU)
-# define COMPILER_ID "Fujitsu"
-# if defined(__FCC_version__)
-# define COMPILER_VERSION __FCC_version__
-# elif defined(__FCC_major__)
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# endif
-# if defined(__fcc_version)
-# define COMPILER_VERSION_INTERNAL DEC(__fcc_version)
-# elif defined(__FCC_VERSION)
-# define COMPILER_VERSION_INTERNAL DEC(__FCC_VERSION)
-# endif
-
-
-#elif defined(__ghs__)
-# define COMPILER_ID "GHS"
-/* __GHS_VERSION_NUMBER = VVVVRP */
-# ifdef __GHS_VERSION_NUMBER
-# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100)
-# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10)
-# endif
-
-#elif defined(__TASKING__)
-# define COMPILER_ID "Tasking"
- # define COMPILER_VERSION_MAJOR DEC(__VERSION__/1000)
- # define COMPILER_VERSION_MINOR DEC(__VERSION__ % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__VERSION__)
-
-#elif defined(__ORANGEC__)
-# define COMPILER_ID "OrangeC"
-# define COMPILER_VERSION_MAJOR DEC(__ORANGEC_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__ORANGEC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__ORANGEC_PATCHLEVEL__)
-
-#elif defined(__TINYC__)
-# define COMPILER_ID "TinyCC"
-
-#elif defined(__BCC__)
-# define COMPILER_ID "Bruce"
-
-#elif defined(__SCO_VERSION__)
-# define COMPILER_ID "SCO"
-
-#elif defined(__ARMCC_VERSION) && !defined(__clang__)
-# define COMPILER_ID "ARMCC"
-#if __ARMCC_VERSION >= 1000000
- /* __ARMCC_VERSION = VRRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#else
- /* __ARMCC_VERSION = VRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#endif
-
-
-#elif defined(__clang__) && defined(__apple_build_version__)
-# define COMPILER_ID "AppleClang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__)
-
-#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION)
-# define COMPILER_ID "ARMClang"
- # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION/100 % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION)
-
-#elif defined(__clang__) && defined(__ti__)
-# define COMPILER_ID "TIClang"
- # define COMPILER_VERSION_MAJOR DEC(__ti_major__)
- # define COMPILER_VERSION_MINOR DEC(__ti_minor__)
- # define COMPILER_VERSION_PATCH DEC(__ti_patchlevel__)
-# define COMPILER_VERSION_INTERNAL DEC(__ti_version__)
-
-#elif defined(__clang__)
-# define COMPILER_ID "Clang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-
-#elif defined(__LCC__) && (defined(__GNUC__) || defined(__GNUG__) || defined(__MCST__))
-# define COMPILER_ID "LCC"
-# define COMPILER_VERSION_MAJOR DEC(__LCC__ / 100)
-# define COMPILER_VERSION_MINOR DEC(__LCC__ % 100)
-# if defined(__LCC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__LCC_MINOR__)
-# endif
-# if defined(__GNUC__) && defined(__GNUC_MINOR__)
-# define SIMULATE_ID "GNU"
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-# endif
-
-#elif defined(__GNUC__)
-# define COMPILER_ID "GNU"
-# define COMPILER_VERSION_MAJOR DEC(__GNUC__)
-# if defined(__GNUC_MINOR__)
-# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif defined(_MSC_VER)
-# define COMPILER_ID "MSVC"
- /* _MSC_VER = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100)
-# if defined(_MSC_FULL_VER)
-# if _MSC_VER >= 1400
- /* _MSC_FULL_VER = VVRRPPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000)
-# else
- /* _MSC_FULL_VER = VVRRPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000)
-# endif
-# endif
-# if defined(_MSC_BUILD)
-# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD)
-# endif
-
-#elif defined(_ADI_COMPILER)
-# define COMPILER_ID "ADSP"
-#if defined(__VERSIONNUM__)
- /* __VERSIONNUM__ = 0xVVRRPPTT */
-# define COMPILER_VERSION_MAJOR DEC(__VERSIONNUM__ >> 24 & 0xFF)
-# define COMPILER_VERSION_MINOR DEC(__VERSIONNUM__ >> 16 & 0xFF)
-# define COMPILER_VERSION_PATCH DEC(__VERSIONNUM__ >> 8 & 0xFF)
-# define COMPILER_VERSION_TWEAK DEC(__VERSIONNUM__ & 0xFF)
-#endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# define COMPILER_ID "IAR"
-# if defined(__VER__) && defined(__ICCARM__)
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000)
-# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000)
-# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__) || defined(__ICCSTM8__))
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100)
-# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100))
-# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# endif
-
-#elif defined(__SDCC_VERSION_MAJOR) || defined(SDCC)
-# define COMPILER_ID "SDCC"
-# if defined(__SDCC_VERSION_MAJOR)
-# define COMPILER_VERSION_MAJOR DEC(__SDCC_VERSION_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(__SDCC_VERSION_MINOR)
-# define COMPILER_VERSION_PATCH DEC(__SDCC_VERSION_PATCH)
-# else
- /* SDCC = VRP */
-# define COMPILER_VERSION_MAJOR DEC(SDCC/100)
-# define COMPILER_VERSION_MINOR DEC(SDCC/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(SDCC % 10)
-# endif
-
-
-/* These compilers are either not known or too old to define an
- identification macro. Try to identify the platform and guess that
- it is the native compiler. */
-#elif defined(__hpux) || defined(__hpua)
-# define COMPILER_ID "HP"
-
-#else /* unknown compiler */
-# define COMPILER_ID ""
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]";
-#ifdef SIMULATE_ID
-char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]";
-#endif
-
-#ifdef __QNXNTO__
-char const* qnxnto = "INFO" ":" "qnxnto[]";
-#endif
-
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
-char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]";
-#endif
-
-#define STRINGIFY_HELPER(X) #X
-#define STRINGIFY(X) STRINGIFY_HELPER(X)
-
-/* Identify known platforms by name. */
-#if defined(__linux) || defined(__linux__) || defined(linux)
-# define PLATFORM_ID "Linux"
-
-#elif defined(__MSYS__)
-# define PLATFORM_ID "MSYS"
-
-#elif defined(__CYGWIN__)
-# define PLATFORM_ID "Cygwin"
-
-#elif defined(__MINGW32__)
-# define PLATFORM_ID "MinGW"
-
-#elif defined(__APPLE__)
-# define PLATFORM_ID "Darwin"
-
-#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
-# define PLATFORM_ID "Windows"
-
-#elif defined(__FreeBSD__) || defined(__FreeBSD)
-# define PLATFORM_ID "FreeBSD"
-
-#elif defined(__NetBSD__) || defined(__NetBSD)
-# define PLATFORM_ID "NetBSD"
-
-#elif defined(__OpenBSD__) || defined(__OPENBSD)
-# define PLATFORM_ID "OpenBSD"
-
-#elif defined(__sun) || defined(sun)
-# define PLATFORM_ID "SunOS"
-
-#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__)
-# define PLATFORM_ID "AIX"
-
-#elif defined(__hpux) || defined(__hpux__)
-# define PLATFORM_ID "HP-UX"
-
-#elif defined(__HAIKU__)
-# define PLATFORM_ID "Haiku"
-
-#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS)
-# define PLATFORM_ID "BeOS"
-
-#elif defined(__QNX__) || defined(__QNXNTO__)
-# define PLATFORM_ID "QNX"
-
-#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__)
-# define PLATFORM_ID "Tru64"
-
-#elif defined(__riscos) || defined(__riscos__)
-# define PLATFORM_ID "RISCos"
-
-#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__)
-# define PLATFORM_ID "SINIX"
-
-#elif defined(__UNIX_SV__)
-# define PLATFORM_ID "UNIX_SV"
-
-#elif defined(__bsdos__)
-# define PLATFORM_ID "BSDOS"
-
-#elif defined(_MPRAS) || defined(MPRAS)
-# define PLATFORM_ID "MP-RAS"
-
-#elif defined(__osf) || defined(__osf__)
-# define PLATFORM_ID "OSF1"
-
-#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv)
-# define PLATFORM_ID "SCO_SV"
-
-#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX)
-# define PLATFORM_ID "ULTRIX"
-
-#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX)
-# define PLATFORM_ID "Xenix"
-
-#elif defined(__WATCOMC__)
-# if defined(__LINUX__)
-# define PLATFORM_ID "Linux"
-
-# elif defined(__DOS__)
-# define PLATFORM_ID "DOS"
-
-# elif defined(__OS2__)
-# define PLATFORM_ID "OS2"
-
-# elif defined(__WINDOWS__)
-# define PLATFORM_ID "Windows3x"
-
-# elif defined(__VXWORKS__)
-# define PLATFORM_ID "VxWorks"
-
-# else /* unknown platform */
-# define PLATFORM_ID
-# endif
-
-#elif defined(__INTEGRITY)
-# if defined(INT_178B)
-# define PLATFORM_ID "Integrity178"
-
-# else /* regular Integrity */
-# define PLATFORM_ID "Integrity"
-# endif
-
-# elif defined(_ADI_COMPILER)
-# define PLATFORM_ID "ADSP"
-
-#else /* unknown platform */
-# define PLATFORM_ID
-
-#endif
-
-/* For windows compilers MSVC and Intel we can determine
- the architecture of the compiler being used. This is because
- the compilers do not have flags that can change the architecture,
- but rather depend on which compiler is being used
-*/
-#if defined(_WIN32) && defined(_MSC_VER)
-# if defined(_M_IA64)
-# define ARCHITECTURE_ID "IA64"
-
-# elif defined(_M_ARM64EC)
-# define ARCHITECTURE_ID "ARM64EC"
-
-# elif defined(_M_X64) || defined(_M_AMD64)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# elif defined(_M_ARM64)
-# define ARCHITECTURE_ID "ARM64"
-
-# elif defined(_M_ARM)
-# if _M_ARM == 4
-# define ARCHITECTURE_ID "ARMV4I"
-# elif _M_ARM == 5
-# define ARCHITECTURE_ID "ARMV5I"
-# else
-# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM)
-# endif
-
-# elif defined(_M_MIPS)
-# define ARCHITECTURE_ID "MIPS"
-
-# elif defined(_M_SH)
-# define ARCHITECTURE_ID "SHx"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__WATCOMC__)
-# if defined(_M_I86)
-# define ARCHITECTURE_ID "I86"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# if defined(__ICCARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__ICCRX__)
-# define ARCHITECTURE_ID "RX"
-
-# elif defined(__ICCRH850__)
-# define ARCHITECTURE_ID "RH850"
-
-# elif defined(__ICCRL78__)
-# define ARCHITECTURE_ID "RL78"
-
-# elif defined(__ICCRISCV__)
-# define ARCHITECTURE_ID "RISCV"
-
-# elif defined(__ICCAVR__)
-# define ARCHITECTURE_ID "AVR"
-
-# elif defined(__ICC430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__ICCV850__)
-# define ARCHITECTURE_ID "V850"
-
-# elif defined(__ICC8051__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__ICCSTM8__)
-# define ARCHITECTURE_ID "STM8"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__ghs__)
-# if defined(__PPC64__)
-# define ARCHITECTURE_ID "PPC64"
-
-# elif defined(__ppc__)
-# define ARCHITECTURE_ID "PPC"
-
-# elif defined(__ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__x86_64__)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(__i386__)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__clang__) && defined(__ti__)
-# if defined(__ARM_ARCH)
-# define ARCHITECTURE_ID "ARM"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__TI_COMPILER_VERSION__)
-# if defined(__TI_ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__MSP430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__TMS320C28XX__)
-# define ARCHITECTURE_ID "TMS320C28x"
-
-# elif defined(__TMS320C6X__) || defined(_TMS320C6X)
-# define ARCHITECTURE_ID "TMS320C6x"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-# elif defined(__ADSPSHARC__)
-# define ARCHITECTURE_ID "SHARC"
-
-# elif defined(__ADSPBLACKFIN__)
-# define ARCHITECTURE_ID "Blackfin"
-
-#elif defined(__TASKING__)
-
-# if defined(__CTC__) || defined(__CPTC__)
-# define ARCHITECTURE_ID "TriCore"
-
-# elif defined(__CMCS__)
-# define ARCHITECTURE_ID "MCS"
-
-# elif defined(__CARM__) || defined(__CPARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__CARC__)
-# define ARCHITECTURE_ID "ARC"
-
-# elif defined(__C51__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__CPCP__)
-# define ARCHITECTURE_ID "PCP"
-
-# else
-# define ARCHITECTURE_ID ""
-# endif
-
-#else
-# define ARCHITECTURE_ID
-#endif
-
-/* Convert integer to decimal digit literals. */
-#define DEC(n) \
- ('0' + (((n) / 10000000)%10)), \
- ('0' + (((n) / 1000000)%10)), \
- ('0' + (((n) / 100000)%10)), \
- ('0' + (((n) / 10000)%10)), \
- ('0' + (((n) / 1000)%10)), \
- ('0' + (((n) / 100)%10)), \
- ('0' + (((n) / 10)%10)), \
- ('0' + ((n) % 10))
-
-/* Convert integer to hex digit literals. */
-#define HEX(n) \
- ('0' + ((n)>>28 & 0xF)), \
- ('0' + ((n)>>24 & 0xF)), \
- ('0' + ((n)>>20 & 0xF)), \
- ('0' + ((n)>>16 & 0xF)), \
- ('0' + ((n)>>12 & 0xF)), \
- ('0' + ((n)>>8 & 0xF)), \
- ('0' + ((n)>>4 & 0xF)), \
- ('0' + ((n) & 0xF))
-
-/* Construct a string literal encoding the version number. */
-#ifdef COMPILER_VERSION
-char const* info_version = "INFO" ":" "compiler_version[" COMPILER_VERSION "]";
-
-/* Construct a string literal encoding the version number components. */
-#elif defined(COMPILER_VERSION_MAJOR)
-char const info_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[',
- COMPILER_VERSION_MAJOR,
-# ifdef COMPILER_VERSION_MINOR
- '.', COMPILER_VERSION_MINOR,
-# ifdef COMPILER_VERSION_PATCH
- '.', COMPILER_VERSION_PATCH,
-# ifdef COMPILER_VERSION_TWEAK
- '.', COMPILER_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct a string literal encoding the internal version number. */
-#ifdef COMPILER_VERSION_INTERNAL
-char const info_version_internal[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_',
- 'i','n','t','e','r','n','a','l','[',
- COMPILER_VERSION_INTERNAL,']','\0'};
-#elif defined(COMPILER_VERSION_INTERNAL_STR)
-char const* info_version_internal = "INFO" ":" "compiler_version_internal[" COMPILER_VERSION_INTERNAL_STR "]";
-#endif
-
-/* Construct a string literal encoding the version number components. */
-#ifdef SIMULATE_VERSION_MAJOR
-char const info_simulate_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[',
- SIMULATE_VERSION_MAJOR,
-# ifdef SIMULATE_VERSION_MINOR
- '.', SIMULATE_VERSION_MINOR,
-# ifdef SIMULATE_VERSION_PATCH
- '.', SIMULATE_VERSION_PATCH,
-# ifdef SIMULATE_VERSION_TWEAK
- '.', SIMULATE_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]";
-char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]";
-
-
-
-#define C_STD_99 199901L
-#define C_STD_11 201112L
-#define C_STD_17 201710L
-#define C_STD_23 202311L
-
-#ifdef __STDC_VERSION__
-# define C_STD __STDC_VERSION__
-#endif
-
-#if !defined(__STDC__) && !defined(__clang__)
-# if defined(_MSC_VER) || defined(__ibmxl__) || defined(__IBMC__)
-# define C_VERSION "90"
-# else
-# define C_VERSION
-# endif
-#elif C_STD > C_STD_17
-# define C_VERSION "23"
-#elif C_STD > C_STD_11
-# define C_VERSION "17"
-#elif C_STD > C_STD_99
-# define C_VERSION "11"
-#elif C_STD >= C_STD_99
-# define C_VERSION "99"
-#else
-# define C_VERSION "90"
-#endif
-const char* info_language_standard_default =
- "INFO" ":" "standard_default[" C_VERSION "]";
-
-const char* info_language_extensions_default = "INFO" ":" "extensions_default["
-#if (defined(__clang__) || defined(__GNUC__) || defined(__xlC__) || \
- defined(__TI_COMPILER_VERSION__)) && \
- !defined(__STRICT_ANSI__)
- "ON"
-#else
- "OFF"
-#endif
-"]";
-
-/*--------------------------------------------------------------------------*/
-
-#ifdef ID_VOID_MAIN
-void main() {}
-#else
-# if defined(__CLASSIC_C__)
-int main(argc, argv) int argc; char *argv[];
-# else
-int main(int argc, char* argv[])
-# endif
-{
- int require = 0;
- require += info_compiler[argc];
- require += info_platform[argc];
- require += info_arch[argc];
-#ifdef COMPILER_VERSION_MAJOR
- require += info_version[argc];
-#endif
-#if defined(COMPILER_VERSION_INTERNAL) || defined(COMPILER_VERSION_INTERNAL_STR)
- require += info_version_internal[argc];
-#endif
-#ifdef SIMULATE_ID
- require += info_simulate[argc];
-#endif
-#ifdef SIMULATE_VERSION_MAJOR
- require += info_simulate_version[argc];
-#endif
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
- require += info_cray[argc];
-#endif
- require += info_language_standard_default[argc];
- require += info_language_extensions_default[argc];
- (void)argv;
- return require;
-}
-#endif
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/a.exe b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/a.exe
deleted file mode 100644
index bb4798d..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/a.exe and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/CMakeCXXCompilerId.cpp b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/CMakeCXXCompilerId.cpp
deleted file mode 100644
index 94d4310..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/CMakeCXXCompilerId.cpp
+++ /dev/null
@@ -1,920 +0,0 @@
-/* This source file must have a .cpp extension so that all C++ compilers
- recognize the extension without flags. Borland does not know .cxx for
- example. */
-#ifndef __cplusplus
-# error "A C compiler has been selected for C++."
-#endif
-
-#if !defined(__has_include)
-/* If the compiler does not have __has_include, pretend the answer is
- always no. */
-# define __has_include(x) 0
-#endif
-
-
-/* Version number components: V=Version, R=Revision, P=Patch
- Version date components: YYYY=Year, MM=Month, DD=Day */
-
-#if defined(__INTEL_COMPILER) || defined(__ICC)
-# define COMPILER_ID "Intel"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-# endif
- /* __INTEL_COMPILER = VRP prior to 2021, and then VVVV for 2021 and later,
- except that a few beta releases use the old format with V=2021. */
-# if __INTEL_COMPILER < 2021 || __INTEL_COMPILER == 202110 || __INTEL_COMPILER == 202111
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER/10 % 10)
-# if defined(__INTEL_COMPILER_UPDATE)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER_UPDATE)
-# else
-# define COMPILER_VERSION_PATCH DEC(__INTEL_COMPILER % 10)
-# endif
-# else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_COMPILER)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_COMPILER_UPDATE)
- /* The third version component from --version is an update index,
- but no macro is provided for it. */
-# define COMPILER_VERSION_PATCH DEC(0)
-# endif
-# if defined(__INTEL_COMPILER_BUILD_DATE)
- /* __INTEL_COMPILER_BUILD_DATE = YYYYMMDD */
-# define COMPILER_VERSION_TWEAK DEC(__INTEL_COMPILER_BUILD_DATE)
-# endif
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif (defined(__clang__) && defined(__INTEL_CLANG_COMPILER)) || defined(__INTEL_LLVM_COMPILER)
-# define COMPILER_ID "IntelLLVM"
-#if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_ID "GNU"
-#endif
-/* __INTEL_LLVM_COMPILER = VVVVRP prior to 2021.2.0, VVVVRRPP for 2021.2.0 and
- * later. Look for 6 digit vs. 8 digit version number to decide encoding.
- * VVVV is no smaller than the current year when a version is released.
- */
-#if __INTEL_LLVM_COMPILER < 1000000L
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/100)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 10)
-#else
-# define COMPILER_VERSION_MAJOR DEC(__INTEL_LLVM_COMPILER/10000)
-# define COMPILER_VERSION_MINOR DEC(__INTEL_LLVM_COMPILER/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__INTEL_LLVM_COMPILER % 100)
-#endif
-#if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-#endif
-#if defined(__GNUC__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-#elif defined(__GNUG__)
-# define SIMULATE_VERSION_MAJOR DEC(__GNUG__)
-#endif
-#if defined(__GNUC_MINOR__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-#endif
-#if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-#endif
-
-#elif defined(__PATHCC__)
-# define COMPILER_ID "PathScale"
-# define COMPILER_VERSION_MAJOR DEC(__PATHCC__)
-# define COMPILER_VERSION_MINOR DEC(__PATHCC_MINOR__)
-# if defined(__PATHCC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PATHCC_PATCHLEVEL__)
-# endif
-
-#elif defined(__BORLANDC__) && defined(__CODEGEARC_VERSION__)
-# define COMPILER_ID "Embarcadero"
-# define COMPILER_VERSION_MAJOR HEX(__CODEGEARC_VERSION__>>24 & 0x00FF)
-# define COMPILER_VERSION_MINOR HEX(__CODEGEARC_VERSION__>>16 & 0x00FF)
-# define COMPILER_VERSION_PATCH DEC(__CODEGEARC_VERSION__ & 0xFFFF)
-
-#elif defined(__BORLANDC__)
-# define COMPILER_ID "Borland"
- /* __BORLANDC__ = 0xVRR */
-# define COMPILER_VERSION_MAJOR HEX(__BORLANDC__>>8)
-# define COMPILER_VERSION_MINOR HEX(__BORLANDC__ & 0xFF)
-
-#elif defined(__WATCOMC__) && __WATCOMC__ < 1200
-# define COMPILER_ID "Watcom"
- /* __WATCOMC__ = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(__WATCOMC__ / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__WATCOMC__)
-# define COMPILER_ID "OpenWatcom"
- /* __WATCOMC__ = VVRP + 1100 */
-# define COMPILER_VERSION_MAJOR DEC((__WATCOMC__ - 1100) / 100)
-# define COMPILER_VERSION_MINOR DEC((__WATCOMC__ / 10) % 10)
-# if (__WATCOMC__ % 10) > 0
-# define COMPILER_VERSION_PATCH DEC(__WATCOMC__ % 10)
-# endif
-
-#elif defined(__SUNPRO_CC)
-# define COMPILER_ID "SunPro"
-# if __SUNPRO_CC >= 0x5100
- /* __SUNPRO_CC = 0xVRRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>12)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xFF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF)
-# else
- /* __SUNPRO_CC = 0xVRP */
-# define COMPILER_VERSION_MAJOR HEX(__SUNPRO_CC>>8)
-# define COMPILER_VERSION_MINOR HEX(__SUNPRO_CC>>4 & 0xF)
-# define COMPILER_VERSION_PATCH HEX(__SUNPRO_CC & 0xF)
-# endif
-
-#elif defined(__HP_aCC)
-# define COMPILER_ID "HP"
- /* __HP_aCC = VVRRPP */
-# define COMPILER_VERSION_MAJOR DEC(__HP_aCC/10000)
-# define COMPILER_VERSION_MINOR DEC(__HP_aCC/100 % 100)
-# define COMPILER_VERSION_PATCH DEC(__HP_aCC % 100)
-
-#elif defined(__DECCXX)
-# define COMPILER_ID "Compaq"
- /* __DECCXX_VER = VVRRTPPPP */
-# define COMPILER_VERSION_MAJOR DEC(__DECCXX_VER/10000000)
-# define COMPILER_VERSION_MINOR DEC(__DECCXX_VER/100000 % 100)
-# define COMPILER_VERSION_PATCH DEC(__DECCXX_VER % 10000)
-
-#elif defined(__IBMCPP__) && defined(__COMPILER_VER__)
-# define COMPILER_ID "zOS"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__open_xl__) && defined(__clang__)
-# define COMPILER_ID "IBMClang"
-# define COMPILER_VERSION_MAJOR DEC(__open_xl_version__)
-# define COMPILER_VERSION_MINOR DEC(__open_xl_release__)
-# define COMPILER_VERSION_PATCH DEC(__open_xl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__open_xl_ptf_fix_level__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__ibmxl__) && defined(__clang__)
-# define COMPILER_ID "XLClang"
-# define COMPILER_VERSION_MAJOR DEC(__ibmxl_version__)
-# define COMPILER_VERSION_MINOR DEC(__ibmxl_release__)
-# define COMPILER_VERSION_PATCH DEC(__ibmxl_modification__)
-# define COMPILER_VERSION_TWEAK DEC(__ibmxl_ptf_fix_level__)
-
-
-#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ >= 800
-# define COMPILER_ID "XL"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__IBMCPP__) && !defined(__COMPILER_VER__) && __IBMCPP__ < 800
-# define COMPILER_ID "VisualAge"
- /* __IBMCPP__ = VRP */
-# define COMPILER_VERSION_MAJOR DEC(__IBMCPP__/100)
-# define COMPILER_VERSION_MINOR DEC(__IBMCPP__/10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__IBMCPP__ % 10)
-
-#elif defined(__NVCOMPILER)
-# define COMPILER_ID "NVHPC"
-# define COMPILER_VERSION_MAJOR DEC(__NVCOMPILER_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__NVCOMPILER_MINOR__)
-# if defined(__NVCOMPILER_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__NVCOMPILER_PATCHLEVEL__)
-# endif
-
-#elif defined(__PGI)
-# define COMPILER_ID "PGI"
-# define COMPILER_VERSION_MAJOR DEC(__PGIC__)
-# define COMPILER_VERSION_MINOR DEC(__PGIC_MINOR__)
-# if defined(__PGIC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__PGIC_PATCHLEVEL__)
-# endif
-
-#elif defined(__clang__) && defined(__cray__)
-# define COMPILER_ID "CrayClang"
-# define COMPILER_VERSION_MAJOR DEC(__cray_major__)
-# define COMPILER_VERSION_MINOR DEC(__cray_minor__)
-# define COMPILER_VERSION_PATCH DEC(__cray_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(_CRAYC)
-# define COMPILER_ID "Cray"
-# define COMPILER_VERSION_MAJOR DEC(_RELEASE_MAJOR)
-# define COMPILER_VERSION_MINOR DEC(_RELEASE_MINOR)
-
-#elif defined(__TI_COMPILER_VERSION__)
-# define COMPILER_ID "TI"
- /* __TI_COMPILER_VERSION__ = VVVRRRPPP */
-# define COMPILER_VERSION_MAJOR DEC(__TI_COMPILER_VERSION__/1000000)
-# define COMPILER_VERSION_MINOR DEC(__TI_COMPILER_VERSION__/1000 % 1000)
-# define COMPILER_VERSION_PATCH DEC(__TI_COMPILER_VERSION__ % 1000)
-
-#elif defined(__CLANG_FUJITSU)
-# define COMPILER_ID "FujitsuClang"
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# define COMPILER_VERSION_INTERNAL_STR __clang_version__
-
-
-#elif defined(__FUJITSU)
-# define COMPILER_ID "Fujitsu"
-# if defined(__FCC_version__)
-# define COMPILER_VERSION __FCC_version__
-# elif defined(__FCC_major__)
-# define COMPILER_VERSION_MAJOR DEC(__FCC_major__)
-# define COMPILER_VERSION_MINOR DEC(__FCC_minor__)
-# define COMPILER_VERSION_PATCH DEC(__FCC_patchlevel__)
-# endif
-# if defined(__fcc_version)
-# define COMPILER_VERSION_INTERNAL DEC(__fcc_version)
-# elif defined(__FCC_VERSION)
-# define COMPILER_VERSION_INTERNAL DEC(__FCC_VERSION)
-# endif
-
-
-#elif defined(__ghs__)
-# define COMPILER_ID "GHS"
-/* __GHS_VERSION_NUMBER = VVVVRP */
-# ifdef __GHS_VERSION_NUMBER
-# define COMPILER_VERSION_MAJOR DEC(__GHS_VERSION_NUMBER / 100)
-# define COMPILER_VERSION_MINOR DEC(__GHS_VERSION_NUMBER / 10 % 10)
-# define COMPILER_VERSION_PATCH DEC(__GHS_VERSION_NUMBER % 10)
-# endif
-
-#elif defined(__TASKING__)
-# define COMPILER_ID "Tasking"
- # define COMPILER_VERSION_MAJOR DEC(__VERSION__/1000)
- # define COMPILER_VERSION_MINOR DEC(__VERSION__ % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__VERSION__)
-
-#elif defined(__ORANGEC__)
-# define COMPILER_ID "OrangeC"
-# define COMPILER_VERSION_MAJOR DEC(__ORANGEC_MAJOR__)
-# define COMPILER_VERSION_MINOR DEC(__ORANGEC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__ORANGEC_PATCHLEVEL__)
-
-#elif defined(__SCO_VERSION__)
-# define COMPILER_ID "SCO"
-
-#elif defined(__ARMCC_VERSION) && !defined(__clang__)
-# define COMPILER_ID "ARMCC"
-#if __ARMCC_VERSION >= 1000000
- /* __ARMCC_VERSION = VRRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#else
- /* __ARMCC_VERSION = VRPPPP */
- # define COMPILER_VERSION_MAJOR DEC(__ARMCC_VERSION/100000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCC_VERSION/10000 % 10)
- # define COMPILER_VERSION_PATCH DEC(__ARMCC_VERSION % 10000)
-#endif
-
-
-#elif defined(__clang__) && defined(__apple_build_version__)
-# define COMPILER_ID "AppleClang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-# define COMPILER_VERSION_TWEAK DEC(__apple_build_version__)
-
-#elif defined(__clang__) && defined(__ARMCOMPILER_VERSION)
-# define COMPILER_ID "ARMClang"
- # define COMPILER_VERSION_MAJOR DEC(__ARMCOMPILER_VERSION/1000000)
- # define COMPILER_VERSION_MINOR DEC(__ARMCOMPILER_VERSION/10000 % 100)
- # define COMPILER_VERSION_PATCH DEC(__ARMCOMPILER_VERSION/100 % 100)
-# define COMPILER_VERSION_INTERNAL DEC(__ARMCOMPILER_VERSION)
-
-#elif defined(__clang__) && defined(__ti__)
-# define COMPILER_ID "TIClang"
- # define COMPILER_VERSION_MAJOR DEC(__ti_major__)
- # define COMPILER_VERSION_MINOR DEC(__ti_minor__)
- # define COMPILER_VERSION_PATCH DEC(__ti_patchlevel__)
-# define COMPILER_VERSION_INTERNAL DEC(__ti_version__)
-
-#elif defined(__clang__)
-# define COMPILER_ID "Clang"
-# if defined(_MSC_VER)
-# define SIMULATE_ID "MSVC"
-# endif
-# define COMPILER_VERSION_MAJOR DEC(__clang_major__)
-# define COMPILER_VERSION_MINOR DEC(__clang_minor__)
-# define COMPILER_VERSION_PATCH DEC(__clang_patchlevel__)
-# if defined(_MSC_VER)
- /* _MSC_VER = VVRR */
-# define SIMULATE_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define SIMULATE_VERSION_MINOR DEC(_MSC_VER % 100)
-# endif
-
-#elif defined(__LCC__) && (defined(__GNUC__) || defined(__GNUG__) || defined(__MCST__))
-# define COMPILER_ID "LCC"
-# define COMPILER_VERSION_MAJOR DEC(__LCC__ / 100)
-# define COMPILER_VERSION_MINOR DEC(__LCC__ % 100)
-# if defined(__LCC_MINOR__)
-# define COMPILER_VERSION_PATCH DEC(__LCC_MINOR__)
-# endif
-# if defined(__GNUC__) && defined(__GNUC_MINOR__)
-# define SIMULATE_ID "GNU"
-# define SIMULATE_VERSION_MAJOR DEC(__GNUC__)
-# define SIMULATE_VERSION_MINOR DEC(__GNUC_MINOR__)
-# if defined(__GNUC_PATCHLEVEL__)
-# define SIMULATE_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-# endif
-
-#elif defined(__GNUC__) || defined(__GNUG__)
-# define COMPILER_ID "GNU"
-# if defined(__GNUC__)
-# define COMPILER_VERSION_MAJOR DEC(__GNUC__)
-# else
-# define COMPILER_VERSION_MAJOR DEC(__GNUG__)
-# endif
-# if defined(__GNUC_MINOR__)
-# define COMPILER_VERSION_MINOR DEC(__GNUC_MINOR__)
-# endif
-# if defined(__GNUC_PATCHLEVEL__)
-# define COMPILER_VERSION_PATCH DEC(__GNUC_PATCHLEVEL__)
-# endif
-
-#elif defined(_MSC_VER)
-# define COMPILER_ID "MSVC"
- /* _MSC_VER = VVRR */
-# define COMPILER_VERSION_MAJOR DEC(_MSC_VER / 100)
-# define COMPILER_VERSION_MINOR DEC(_MSC_VER % 100)
-# if defined(_MSC_FULL_VER)
-# if _MSC_VER >= 1400
- /* _MSC_FULL_VER = VVRRPPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 100000)
-# else
- /* _MSC_FULL_VER = VVRRPPPP */
-# define COMPILER_VERSION_PATCH DEC(_MSC_FULL_VER % 10000)
-# endif
-# endif
-# if defined(_MSC_BUILD)
-# define COMPILER_VERSION_TWEAK DEC(_MSC_BUILD)
-# endif
-
-#elif defined(_ADI_COMPILER)
-# define COMPILER_ID "ADSP"
-#if defined(__VERSIONNUM__)
- /* __VERSIONNUM__ = 0xVVRRPPTT */
-# define COMPILER_VERSION_MAJOR DEC(__VERSIONNUM__ >> 24 & 0xFF)
-# define COMPILER_VERSION_MINOR DEC(__VERSIONNUM__ >> 16 & 0xFF)
-# define COMPILER_VERSION_PATCH DEC(__VERSIONNUM__ >> 8 & 0xFF)
-# define COMPILER_VERSION_TWEAK DEC(__VERSIONNUM__ & 0xFF)
-#endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# define COMPILER_ID "IAR"
-# if defined(__VER__) && defined(__ICCARM__)
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 1000000)
-# define COMPILER_VERSION_MINOR DEC(((__VER__) / 1000) % 1000)
-# define COMPILER_VERSION_PATCH DEC((__VER__) % 1000)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# elif defined(__VER__) && (defined(__ICCAVR__) || defined(__ICCRX__) || defined(__ICCRH850__) || defined(__ICCRL78__) || defined(__ICC430__) || defined(__ICCRISCV__) || defined(__ICCV850__) || defined(__ICC8051__) || defined(__ICCSTM8__))
-# define COMPILER_VERSION_MAJOR DEC((__VER__) / 100)
-# define COMPILER_VERSION_MINOR DEC((__VER__) - (((__VER__) / 100)*100))
-# define COMPILER_VERSION_PATCH DEC(__SUBVERSION__)
-# define COMPILER_VERSION_INTERNAL DEC(__IAR_SYSTEMS_ICC__)
-# endif
-
-
-/* These compilers are either not known or too old to define an
- identification macro. Try to identify the platform and guess that
- it is the native compiler. */
-#elif defined(__hpux) || defined(__hpua)
-# define COMPILER_ID "HP"
-
-#else /* unknown compiler */
-# define COMPILER_ID ""
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_compiler = "INFO" ":" "compiler[" COMPILER_ID "]";
-#ifdef SIMULATE_ID
-char const* info_simulate = "INFO" ":" "simulate[" SIMULATE_ID "]";
-#endif
-
-#ifdef __QNXNTO__
-char const* qnxnto = "INFO" ":" "qnxnto[]";
-#endif
-
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
-char const *info_cray = "INFO" ":" "compiler_wrapper[CrayPrgEnv]";
-#endif
-
-#define STRINGIFY_HELPER(X) #X
-#define STRINGIFY(X) STRINGIFY_HELPER(X)
-
-/* Identify known platforms by name. */
-#if defined(__linux) || defined(__linux__) || defined(linux)
-# define PLATFORM_ID "Linux"
-
-#elif defined(__MSYS__)
-# define PLATFORM_ID "MSYS"
-
-#elif defined(__CYGWIN__)
-# define PLATFORM_ID "Cygwin"
-
-#elif defined(__MINGW32__)
-# define PLATFORM_ID "MinGW"
-
-#elif defined(__APPLE__)
-# define PLATFORM_ID "Darwin"
-
-#elif defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
-# define PLATFORM_ID "Windows"
-
-#elif defined(__FreeBSD__) || defined(__FreeBSD)
-# define PLATFORM_ID "FreeBSD"
-
-#elif defined(__NetBSD__) || defined(__NetBSD)
-# define PLATFORM_ID "NetBSD"
-
-#elif defined(__OpenBSD__) || defined(__OPENBSD)
-# define PLATFORM_ID "OpenBSD"
-
-#elif defined(__sun) || defined(sun)
-# define PLATFORM_ID "SunOS"
-
-#elif defined(_AIX) || defined(__AIX) || defined(__AIX__) || defined(__aix) || defined(__aix__)
-# define PLATFORM_ID "AIX"
-
-#elif defined(__hpux) || defined(__hpux__)
-# define PLATFORM_ID "HP-UX"
-
-#elif defined(__HAIKU__)
-# define PLATFORM_ID "Haiku"
-
-#elif defined(__BeOS) || defined(__BEOS__) || defined(_BEOS)
-# define PLATFORM_ID "BeOS"
-
-#elif defined(__QNX__) || defined(__QNXNTO__)
-# define PLATFORM_ID "QNX"
-
-#elif defined(__tru64) || defined(_tru64) || defined(__TRU64__)
-# define PLATFORM_ID "Tru64"
-
-#elif defined(__riscos) || defined(__riscos__)
-# define PLATFORM_ID "RISCos"
-
-#elif defined(__sinix) || defined(__sinix__) || defined(__SINIX__)
-# define PLATFORM_ID "SINIX"
-
-#elif defined(__UNIX_SV__)
-# define PLATFORM_ID "UNIX_SV"
-
-#elif defined(__bsdos__)
-# define PLATFORM_ID "BSDOS"
-
-#elif defined(_MPRAS) || defined(MPRAS)
-# define PLATFORM_ID "MP-RAS"
-
-#elif defined(__osf) || defined(__osf__)
-# define PLATFORM_ID "OSF1"
-
-#elif defined(_SCO_SV) || defined(SCO_SV) || defined(sco_sv)
-# define PLATFORM_ID "SCO_SV"
-
-#elif defined(__ultrix) || defined(__ultrix__) || defined(_ULTRIX)
-# define PLATFORM_ID "ULTRIX"
-
-#elif defined(__XENIX__) || defined(_XENIX) || defined(XENIX)
-# define PLATFORM_ID "Xenix"
-
-#elif defined(__WATCOMC__)
-# if defined(__LINUX__)
-# define PLATFORM_ID "Linux"
-
-# elif defined(__DOS__)
-# define PLATFORM_ID "DOS"
-
-# elif defined(__OS2__)
-# define PLATFORM_ID "OS2"
-
-# elif defined(__WINDOWS__)
-# define PLATFORM_ID "Windows3x"
-
-# elif defined(__VXWORKS__)
-# define PLATFORM_ID "VxWorks"
-
-# else /* unknown platform */
-# define PLATFORM_ID
-# endif
-
-#elif defined(__INTEGRITY)
-# if defined(INT_178B)
-# define PLATFORM_ID "Integrity178"
-
-# else /* regular Integrity */
-# define PLATFORM_ID "Integrity"
-# endif
-
-# elif defined(_ADI_COMPILER)
-# define PLATFORM_ID "ADSP"
-
-#else /* unknown platform */
-# define PLATFORM_ID
-
-#endif
-
-/* For windows compilers MSVC and Intel we can determine
- the architecture of the compiler being used. This is because
- the compilers do not have flags that can change the architecture,
- but rather depend on which compiler is being used
-*/
-#if defined(_WIN32) && defined(_MSC_VER)
-# if defined(_M_IA64)
-# define ARCHITECTURE_ID "IA64"
-
-# elif defined(_M_ARM64EC)
-# define ARCHITECTURE_ID "ARM64EC"
-
-# elif defined(_M_X64) || defined(_M_AMD64)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# elif defined(_M_ARM64)
-# define ARCHITECTURE_ID "ARM64"
-
-# elif defined(_M_ARM)
-# if _M_ARM == 4
-# define ARCHITECTURE_ID "ARMV4I"
-# elif _M_ARM == 5
-# define ARCHITECTURE_ID "ARMV5I"
-# else
-# define ARCHITECTURE_ID "ARMV" STRINGIFY(_M_ARM)
-# endif
-
-# elif defined(_M_MIPS)
-# define ARCHITECTURE_ID "MIPS"
-
-# elif defined(_M_SH)
-# define ARCHITECTURE_ID "SHx"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__WATCOMC__)
-# if defined(_M_I86)
-# define ARCHITECTURE_ID "I86"
-
-# elif defined(_M_IX86)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__IAR_SYSTEMS_ICC__) || defined(__IAR_SYSTEMS_ICC)
-# if defined(__ICCARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__ICCRX__)
-# define ARCHITECTURE_ID "RX"
-
-# elif defined(__ICCRH850__)
-# define ARCHITECTURE_ID "RH850"
-
-# elif defined(__ICCRL78__)
-# define ARCHITECTURE_ID "RL78"
-
-# elif defined(__ICCRISCV__)
-# define ARCHITECTURE_ID "RISCV"
-
-# elif defined(__ICCAVR__)
-# define ARCHITECTURE_ID "AVR"
-
-# elif defined(__ICC430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__ICCV850__)
-# define ARCHITECTURE_ID "V850"
-
-# elif defined(__ICC8051__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__ICCSTM8__)
-# define ARCHITECTURE_ID "STM8"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__ghs__)
-# if defined(__PPC64__)
-# define ARCHITECTURE_ID "PPC64"
-
-# elif defined(__ppc__)
-# define ARCHITECTURE_ID "PPC"
-
-# elif defined(__ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__x86_64__)
-# define ARCHITECTURE_ID "x64"
-
-# elif defined(__i386__)
-# define ARCHITECTURE_ID "X86"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__clang__) && defined(__ti__)
-# if defined(__ARM_ARCH)
-# define ARCHITECTURE_ID "ARM"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-#elif defined(__TI_COMPILER_VERSION__)
-# if defined(__TI_ARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__MSP430__)
-# define ARCHITECTURE_ID "MSP430"
-
-# elif defined(__TMS320C28XX__)
-# define ARCHITECTURE_ID "TMS320C28x"
-
-# elif defined(__TMS320C6X__) || defined(_TMS320C6X)
-# define ARCHITECTURE_ID "TMS320C6x"
-
-# else /* unknown architecture */
-# define ARCHITECTURE_ID ""
-# endif
-
-# elif defined(__ADSPSHARC__)
-# define ARCHITECTURE_ID "SHARC"
-
-# elif defined(__ADSPBLACKFIN__)
-# define ARCHITECTURE_ID "Blackfin"
-
-#elif defined(__TASKING__)
-
-# if defined(__CTC__) || defined(__CPTC__)
-# define ARCHITECTURE_ID "TriCore"
-
-# elif defined(__CMCS__)
-# define ARCHITECTURE_ID "MCS"
-
-# elif defined(__CARM__) || defined(__CPARM__)
-# define ARCHITECTURE_ID "ARM"
-
-# elif defined(__CARC__)
-# define ARCHITECTURE_ID "ARC"
-
-# elif defined(__C51__)
-# define ARCHITECTURE_ID "8051"
-
-# elif defined(__CPCP__)
-# define ARCHITECTURE_ID "PCP"
-
-# else
-# define ARCHITECTURE_ID ""
-# endif
-
-#else
-# define ARCHITECTURE_ID
-#endif
-
-/* Convert integer to decimal digit literals. */
-#define DEC(n) \
- ('0' + (((n) / 10000000)%10)), \
- ('0' + (((n) / 1000000)%10)), \
- ('0' + (((n) / 100000)%10)), \
- ('0' + (((n) / 10000)%10)), \
- ('0' + (((n) / 1000)%10)), \
- ('0' + (((n) / 100)%10)), \
- ('0' + (((n) / 10)%10)), \
- ('0' + ((n) % 10))
-
-/* Convert integer to hex digit literals. */
-#define HEX(n) \
- ('0' + ((n)>>28 & 0xF)), \
- ('0' + ((n)>>24 & 0xF)), \
- ('0' + ((n)>>20 & 0xF)), \
- ('0' + ((n)>>16 & 0xF)), \
- ('0' + ((n)>>12 & 0xF)), \
- ('0' + ((n)>>8 & 0xF)), \
- ('0' + ((n)>>4 & 0xF)), \
- ('0' + ((n) & 0xF))
-
-/* Construct a string literal encoding the version number. */
-#ifdef COMPILER_VERSION
-char const* info_version = "INFO" ":" "compiler_version[" COMPILER_VERSION "]";
-
-/* Construct a string literal encoding the version number components. */
-#elif defined(COMPILER_VERSION_MAJOR)
-char const info_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','[',
- COMPILER_VERSION_MAJOR,
-# ifdef COMPILER_VERSION_MINOR
- '.', COMPILER_VERSION_MINOR,
-# ifdef COMPILER_VERSION_PATCH
- '.', COMPILER_VERSION_PATCH,
-# ifdef COMPILER_VERSION_TWEAK
- '.', COMPILER_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct a string literal encoding the internal version number. */
-#ifdef COMPILER_VERSION_INTERNAL
-char const info_version_internal[] = {
- 'I', 'N', 'F', 'O', ':',
- 'c','o','m','p','i','l','e','r','_','v','e','r','s','i','o','n','_',
- 'i','n','t','e','r','n','a','l','[',
- COMPILER_VERSION_INTERNAL,']','\0'};
-#elif defined(COMPILER_VERSION_INTERNAL_STR)
-char const* info_version_internal = "INFO" ":" "compiler_version_internal[" COMPILER_VERSION_INTERNAL_STR "]";
-#endif
-
-/* Construct a string literal encoding the version number components. */
-#ifdef SIMULATE_VERSION_MAJOR
-char const info_simulate_version[] = {
- 'I', 'N', 'F', 'O', ':',
- 's','i','m','u','l','a','t','e','_','v','e','r','s','i','o','n','[',
- SIMULATE_VERSION_MAJOR,
-# ifdef SIMULATE_VERSION_MINOR
- '.', SIMULATE_VERSION_MINOR,
-# ifdef SIMULATE_VERSION_PATCH
- '.', SIMULATE_VERSION_PATCH,
-# ifdef SIMULATE_VERSION_TWEAK
- '.', SIMULATE_VERSION_TWEAK,
-# endif
-# endif
-# endif
- ']','\0'};
-#endif
-
-/* Construct the string literal in pieces to prevent the source from
- getting matched. Store it in a pointer rather than an array
- because some compilers will just produce instructions to fill the
- array rather than assigning a pointer to a static array. */
-char const* info_platform = "INFO" ":" "platform[" PLATFORM_ID "]";
-char const* info_arch = "INFO" ":" "arch[" ARCHITECTURE_ID "]";
-
-
-
-#define CXX_STD_98 199711L
-#define CXX_STD_11 201103L
-#define CXX_STD_14 201402L
-#define CXX_STD_17 201703L
-#define CXX_STD_20 202002L
-#define CXX_STD_23 202302L
-
-#if defined(__INTEL_COMPILER) && defined(_MSVC_LANG)
-# if _MSVC_LANG > CXX_STD_17
-# define CXX_STD _MSVC_LANG
-# elif _MSVC_LANG == CXX_STD_17 && defined(__cpp_aggregate_paren_init)
-# define CXX_STD CXX_STD_20
-# elif _MSVC_LANG > CXX_STD_14 && __cplusplus > CXX_STD_17
-# define CXX_STD CXX_STD_20
-# elif _MSVC_LANG > CXX_STD_14
-# define CXX_STD CXX_STD_17
-# elif defined(__INTEL_CXX11_MODE__) && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# elif defined(__INTEL_CXX11_MODE__)
-# define CXX_STD CXX_STD_11
-# else
-# define CXX_STD CXX_STD_98
-# endif
-#elif defined(_MSC_VER) && defined(_MSVC_LANG)
-# if _MSVC_LANG > __cplusplus
-# define CXX_STD _MSVC_LANG
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif defined(__NVCOMPILER)
-# if __cplusplus == CXX_STD_17 && defined(__cpp_aggregate_paren_init)
-# define CXX_STD CXX_STD_20
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif defined(__INTEL_COMPILER) || defined(__PGI)
-# if __cplusplus == CXX_STD_11 && defined(__cpp_namespace_attributes)
-# define CXX_STD CXX_STD_17
-# elif __cplusplus == CXX_STD_11 && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif (defined(__IBMCPP__) || defined(__ibmxl__)) && defined(__linux__)
-# if __cplusplus == CXX_STD_11 && defined(__cpp_aggregate_nsdmi)
-# define CXX_STD CXX_STD_14
-# else
-# define CXX_STD __cplusplus
-# endif
-#elif __cplusplus == 1 && defined(__GXX_EXPERIMENTAL_CXX0X__)
-# define CXX_STD CXX_STD_11
-#else
-# define CXX_STD __cplusplus
-#endif
-
-const char* info_language_standard_default = "INFO" ":" "standard_default["
-#if CXX_STD > CXX_STD_23
- "26"
-#elif CXX_STD > CXX_STD_20
- "23"
-#elif CXX_STD > CXX_STD_17
- "20"
-#elif CXX_STD > CXX_STD_14
- "17"
-#elif CXX_STD > CXX_STD_11
- "14"
-#elif CXX_STD >= CXX_STD_11
- "11"
-#else
- "98"
-#endif
-"]";
-
-const char* info_language_extensions_default = "INFO" ":" "extensions_default["
-#if (defined(__clang__) || defined(__GNUC__) || defined(__xlC__) || \
- defined(__TI_COMPILER_VERSION__)) && \
- !defined(__STRICT_ANSI__)
- "ON"
-#else
- "OFF"
-#endif
-"]";
-
-/*--------------------------------------------------------------------------*/
-
-int main(int argc, char* argv[])
-{
- int require = 0;
- require += info_compiler[argc];
- require += info_platform[argc];
- require += info_arch[argc];
-#ifdef COMPILER_VERSION_MAJOR
- require += info_version[argc];
-#endif
-#if defined(COMPILER_VERSION_INTERNAL) || defined(COMPILER_VERSION_INTERNAL_STR)
- require += info_version_internal[argc];
-#endif
-#ifdef SIMULATE_ID
- require += info_simulate[argc];
-#endif
-#ifdef SIMULATE_VERSION_MAJOR
- require += info_simulate_version[argc];
-#endif
-#if defined(__CRAYXT_COMPUTE_LINUX_TARGET)
- require += info_cray[argc];
-#endif
- require += info_language_standard_default[argc];
- require += info_language_extensions_default[argc];
- (void)argv;
- return require;
-}
diff --git a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/a.exe b/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/a.exe
deleted file mode 100644
index ce29567..0000000
Binary files a/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/a.exe and /dev/null differ
diff --git a/assignment1/cmake-build-debug/CMakeFiles/CMakeConfigureLog.yaml b/assignment1/cmake-build-debug/CMakeFiles/CMakeConfigureLog.yaml
deleted file mode 100644
index b5b85bf..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/CMakeConfigureLog.yaml
+++ /dev/null
@@ -1,561 +0,0 @@
-
----
-events:
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineSystem.cmake:205 (message)"
- - "CMakeLists.txt:2 (project)"
- message: |
- The system is: Windows - 10.0.26100 - AMD64
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerId.cmake:17 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerId.cmake:64 (__determine_compiler_id_test)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCCompiler.cmake:123 (CMAKE_DETERMINE_COMPILER_ID)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Compiling the C compiler identification source file "CMakeCCompilerId.c" succeeded.
- Compiler: C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/gcc.exe
- Build flags:
- Id flags:
-
- The output was:
- 0
-
-
- Compilation of the C compiler identification source "CMakeCCompilerId.c" produced "a.exe"
-
- The C compiler identification is GNU, found in:
- C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdC/a.exe
-
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerId.cmake:17 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerId.cmake:64 (__determine_compiler_id_test)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCXXCompiler.cmake:126 (CMAKE_DETERMINE_COMPILER_ID)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Compiling the CXX compiler identification source file "CMakeCXXCompilerId.cpp" succeeded.
- Compiler: C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/g++.exe
- Build flags:
- Id flags:
-
- The output was:
- 0
-
-
- Compilation of the CXX compiler identification source "CMakeCXXCompilerId.cpp" produced "a.exe"
-
- The CXX compiler identification is GNU, found in:
- C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/4.0.2/CompilerIdCXX/a.exe
-
- -
- kind: "try_compile-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:83 (try_compile)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- checks:
- - "Detecting C compiler ABI info"
- directories:
- source: "C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-de4ycb"
- binary: "C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-de4ycb"
- cmakeVariables:
- CMAKE_C_FLAGS: ""
- CMAKE_C_FLAGS_DEBUG: "-g"
- CMAKE_EXE_LINKER_FLAGS: ""
- buildResult:
- variable: "CMAKE_C_ABI_COMPILED"
- cached: true
- stdout: |
- Change Dir: 'C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-de4ycb'
-
- Run Build Command(s): C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe -v cmTC_312ff
- [1/2] C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe -fdiagnostics-color=always -v -o CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj -c C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCCompilerABI.c
- Using built-in specs.
- COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe
- Target: x86_64-w64-mingw32
- Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends
- Thread model: posix
- Supported LTO compression algorithms: zlib
- gcc version 13.1.0 (GCC)
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/'
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/cc1.exe -quiet -v -iprefix C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/ -D_REENTRANT C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCCompilerABI.c -quiet -dumpdir CMakeFiles/cmTC_312ff.dir/ -dumpbase CMakeCCompilerABI.c.c -dumpbase-ext .c -mtune=generic -march=nocona -version -fdiagnostics-color=always -o C:\\Users\\csand\\AppData\\Local\\Temp\\ccReOEGX.s
- GNU C17 (GCC) version 13.1.0 (x86_64-w64-mingw32)
- compiled by GNU C version 13.1.0, GMP version 6.2.1, MPFR version 4.2.0-p4, MPC version 1.3.1, isl version none
- GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include"
- ignoring nonexistent directory "/win/include"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../include"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include"
- ignoring nonexistent directory "/mingw/include"
- #include "..." search starts here:
- #include <...> search starts here:
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include
- End of search list.
- Compiler executable checksum: 2aa4fcf5c9208168c5e2d38a58fc2a97
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/'
- as -v -o CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj C:\\Users\\csand\\AppData\\Local\\Temp\\ccReOEGX.s
- GNU assembler version 2.40 (x86_64-w64-mingw32) using BFD version (GNU Binutils) 2.40
- COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/
- LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../\x0d
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.'\x0d
- [2/2] C:\\WINDOWS\\system32\\cmd.exe /C "cd . && C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe -v -Wl,-v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj -o cmTC_312ff.exe -Wl,--out-implib,libcmTC_312ff.dll.a -Wl,--major-image-version,0,--minor-image-version,0 && cd ."
- Using built-in specs.
- COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe
- COLLECT_LTO_WRAPPER=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/lto-wrapper.exe
- Target: x86_64-w64-mingw32
- Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends
- Thread model: posix
- Supported LTO compression algorithms: zlib
- gcc version 13.1.0 (GCC)
- COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/
- LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../
- COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_312ff.exe' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_312ff.'
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe -m i386pep -Bdynamic -o cmTC_312ff.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj --out-implib libcmTC_312ff.dll.a --major-image-version 0 --minor-image-version 0 -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o
- collect2 version 13.1.0
- C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin/ld.exe -m i386pep -Bdynamic -o cmTC_312ff.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj --out-implib libcmTC_312ff.dll.a --major-image-version 0 --minor-image-version 0 -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o\x0d
- GNU ld (GNU Binutils) 2.40\x0d
- COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_312ff.exe' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_312ff.'\x0d
-
- exitCode: 0
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:191 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Parsed C implicit include dir info: rv=done
- found start of include info
- found start of implicit include info
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include]
- end of search list found
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include]
- implicit include dirs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include]
-
-
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:227 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Parsed C implicit link information:
- link line regex: [^( *|.*[/\\])(ld[0-9]*(|\\.[a-rt-z][a-z]*|\\.s[a-np-z][a-z]*|\\.so[a-z]+)|CMAKE_LINK_STARTFILE-NOTFOUND|([^/\\]+-)?ld|collect2)[^/\\]*( |$)]
- linker tool regex: [^[ ]*(->|")?[ ]*(([^"]*[/\\])?(ld[0-9]*(|\\.[a-rt-z][a-z]*|\\.s[a-np-z][a-z]*|\\.so[a-z]+)))("|,| |$)]
- ignore line: [Change Dir: 'C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-de4ycb']
- ignore line: []
- ignore line: [Run Build Command(s): C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe -v cmTC_312ff]
- ignore line: [[1/2] C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe -fdiagnostics-color=always -v -o CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj -c C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCCompilerABI.c]
- ignore line: [Using built-in specs.]
- ignore line: [COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe]
- ignore line: [Target: x86_64-w64-mingw32]
- ignore line: [Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends]
- ignore line: [Thread model: posix]
- ignore line: [Supported LTO compression algorithms: zlib]
- ignore line: [gcc version 13.1.0 (GCC) ]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/']
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/cc1.exe -quiet -v -iprefix C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/ -D_REENTRANT C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCCompilerABI.c -quiet -dumpdir CMakeFiles/cmTC_312ff.dir/ -dumpbase CMakeCCompilerABI.c.c -dumpbase-ext .c -mtune=generic -march=nocona -version -fdiagnostics-color=always -o C:\\Users\\csand\\AppData\\Local\\Temp\\ccReOEGX.s]
- ignore line: [GNU C17 (GCC) version 13.1.0 (x86_64-w64-mingw32)]
- ignore line: [ compiled by GNU C version 13.1.0 GMP version 6.2.1 MPFR version 4.2.0-p4 MPC version 1.3.1 isl version none]
- ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include"]
- ignore line: [ignoring nonexistent directory "/win/include"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../include"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include"]
- ignore line: [ignoring nonexistent directory "/mingw/include"]
- ignore line: [#include "..." search starts here:]
- ignore line: [#include <...> search starts here:]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include]
- ignore line: [End of search list.]
- ignore line: [Compiler executable checksum: 2aa4fcf5c9208168c5e2d38a58fc2a97]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/']
- ignore line: [ as -v -o CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj C:\\Users\\csand\\AppData\\Local\\Temp\\ccReOEGX.s]
- ignore line: [GNU assembler version 2.40 (x86_64-w64-mingw32) using BFD version (GNU Binutils) 2.40]
- ignore line: [COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/]
- ignore line: [LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../\x0d]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj' '-c' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.'\x0d]
- ignore line: [[2/2] C:\\WINDOWS\\system32\\cmd.exe /C "cd . && C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe -v -Wl -v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj -o cmTC_312ff.exe -Wl --out-implib libcmTC_312ff.dll.a -Wl --major-image-version 0 --minor-image-version 0 && cd ."]
- ignore line: [Using built-in specs.]
- ignore line: [COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\gcc.exe]
- ignore line: [COLLECT_LTO_WRAPPER=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/lto-wrapper.exe]
- ignore line: [Target: x86_64-w64-mingw32]
- ignore line: [Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends]
- ignore line: [Thread model: posix]
- ignore line: [Supported LTO compression algorithms: zlib]
- ignore line: [gcc version 13.1.0 (GCC) ]
- ignore line: [COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/]
- ignore line: [LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../]
- ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_312ff.exe' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_312ff.']
- link line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe -m i386pep -Bdynamic -o cmTC_312ff.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj --out-implib libcmTC_312ff.dll.a --major-image-version 0 --minor-image-version 0 -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe] ==> ignore
- arg [-m] ==> ignore
- arg [i386pep] ==> ignore
- arg [-Bdynamic] ==> search dynamic
- arg [-o] ==> ignore
- arg [cmTC_312ff.exe] ==> ignore
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..]
- arg [-v] ==> ignore
- arg [CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj] ==> ignore
- arg [--out-implib] ==> ignore
- arg [libcmTC_312ff.dll.a] ==> ignore
- arg [--major-image-version] ==> ignore
- arg [0] ==> ignore
- arg [--minor-image-version] ==> ignore
- arg [0] ==> ignore
- arg [-lmingw32] ==> lib [mingw32]
- arg [-lgcc] ==> lib [gcc]
- arg [-lgcc_eh] ==> lib [gcc_eh]
- arg [-lmoldname] ==> lib [moldname]
- arg [-lmingwex] ==> lib [mingwex]
- arg [-lmsvcrt] ==> lib [msvcrt]
- arg [-lkernel32] ==> lib [kernel32]
- arg [-lpthread] ==> lib [pthread]
- arg [-ladvapi32] ==> lib [advapi32]
- arg [-lshell32] ==> lib [shell32]
- arg [-luser32] ==> lib [user32]
- arg [-lkernel32] ==> lib [kernel32]
- arg [-liconv] ==> lib [iconv]
- arg [-lmingw32] ==> lib [mingw32]
- arg [-lgcc] ==> lib [gcc]
- arg [-lgcc_eh] ==> lib [gcc_eh]
- arg [-lmoldname] ==> lib [moldname]
- arg [-lmingwex] ==> lib [mingwex]
- arg [-lmsvcrt] ==> lib [msvcrt]
- arg [-lkernel32] ==> lib [kernel32]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- ignore line: [collect2 version 13.1.0]
- ignore line: [C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin/ld.exe -m i386pep -Bdynamic -o cmTC_312ff.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_312ff.dir/CMakeCCompilerABI.c.obj --out-implib libcmTC_312ff.dll.a --major-image-version 0 --minor-image-version 0 -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc -lgcc_eh -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o\x0d]
- linker tool for 'C': C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe
- remove lib [gcc_eh]
- remove lib [msvcrt]
- remove lib [gcc_eh]
- remove lib [msvcrt]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/crt2.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/default-manifest.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- implicit libs: [mingw32;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc;moldname;mingwex;kernel32]
- implicit objs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/crt2.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/default-manifest.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- implicit dirs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- implicit fwks: []
-
-
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeDetermineLinkerId.cmake:36 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:270 (cmake_determine_linker_id)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Running the C compiler's linker: "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe" "-v"
- GNU ld (GNU Binutils) 2.40
- -
- kind: "try_compile-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:83 (try_compile)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCXXCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- checks:
- - "Detecting CXX compiler ABI info"
- directories:
- source: "C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-1or47y"
- binary: "C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-1or47y"
- cmakeVariables:
- CMAKE_CXX_FLAGS: ""
- CMAKE_CXX_FLAGS_DEBUG: "-g"
- CMAKE_CXX_SCAN_FOR_MODULES: "OFF"
- CMAKE_EXE_LINKER_FLAGS: ""
- buildResult:
- variable: "CMAKE_CXX_ABI_COMPILED"
- cached: true
- stdout: |
- Change Dir: 'C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-1or47y'
-
- Run Build Command(s): C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe -v cmTC_38c76
- [1/2] C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe -fdiagnostics-color=always -v -o CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj -c C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXCompilerABI.cpp
- Using built-in specs.
- COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe
- Target: x86_64-w64-mingw32
- Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends
- Thread model: posix
- Supported LTO compression algorithms: zlib
- gcc version 13.1.0 (GCC)
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/'
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/cc1plus.exe -quiet -v -iprefix C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/ -D_REENTRANT C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXCompilerABI.cpp -quiet -dumpdir CMakeFiles/cmTC_38c76.dir/ -dumpbase CMakeCXXCompilerABI.cpp.cpp -dumpbase-ext .cpp -mtune=generic -march=nocona -version -fdiagnostics-color=always -o C:\\Users\\csand\\AppData\\Local\\Temp\\ccUtd0Pk.s
- GNU C++17 (GCC) version 13.1.0 (x86_64-w64-mingw32)
- compiled by GNU C version 13.1.0, GMP version 6.2.1, MPFR version 4.2.0-p4, MPC version 1.3.1, isl version none
- GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include"
- ignoring nonexistent directory "/win/include"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../include"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed"
- ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include"
- ignoring nonexistent directory "/mingw/include"
- #include "..." search starts here:
- #include <...> search starts here:
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include
- End of search list.
- Compiler executable checksum: e75de627edc3c57e31324b930b15b056
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/'
- as -v -o CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj C:\\Users\\csand\\AppData\\Local\\Temp\\ccUtd0Pk.s
- GNU assembler version 2.40 (x86_64-w64-mingw32) using BFD version (GNU Binutils) 2.40
- COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/
- LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../
- COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.'\x0d
- [2/2] C:\\WINDOWS\\system32\\cmd.exe /C "cd . && C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe -v -Wl,-v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj -o cmTC_38c76.exe -Wl,--out-implib,libcmTC_38c76.dll.a -Wl,--major-image-version,0,--minor-image-version,0 && cd ."
- Using built-in specs.
- COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe
- COLLECT_LTO_WRAPPER=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/lto-wrapper.exe
- Target: x86_64-w64-mingw32
- Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends
- Thread model: posix
- Supported LTO compression algorithms: zlib
- gcc version 13.1.0 (GCC)
- COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/
- LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../
- COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_38c76.exe' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_38c76.'
- C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe -m i386pep -Bdynamic -o cmTC_38c76.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj --out-implib libcmTC_38c76.dll.a --major-image-version 0 --minor-image-version 0 -lstdc++ -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o
- collect2 version 13.1.0
- C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin/ld.exe -m i386pep -Bdynamic -o cmTC_38c76.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj --out-implib libcmTC_38c76.dll.a --major-image-version 0 --minor-image-version 0 -lstdc++ -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o
- GNU ld (GNU Binutils) 2.40
- COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_38c76.exe' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_38c76.'\x0d
-
- exitCode: 0
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:191 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCXXCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Parsed CXX implicit include dir info: rv=done
- found start of include info
- found start of implicit include info
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- add: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include]
- end of search list found
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- collapse include dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include]
- implicit include dirs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/include;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/include]
-
-
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:227 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCXXCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Parsed CXX implicit link information:
- link line regex: [^( *|.*[/\\])(ld[0-9]*(|\\.[a-rt-z][a-z]*|\\.s[a-np-z][a-z]*|\\.so[a-z]+)|CMAKE_LINK_STARTFILE-NOTFOUND|([^/\\]+-)?ld|collect2)[^/\\]*( |$)]
- linker tool regex: [^[ ]*(->|")?[ ]*(([^"]*[/\\])?(ld[0-9]*(|\\.[a-rt-z][a-z]*|\\.s[a-np-z][a-z]*|\\.so[a-z]+)))("|,| |$)]
- ignore line: [Change Dir: 'C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/CMakeScratch/TryCompile-1or47y']
- ignore line: []
- ignore line: [Run Build Command(s): C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe -v cmTC_38c76]
- ignore line: [[1/2] C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe -fdiagnostics-color=always -v -o CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj -c C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXCompilerABI.cpp]
- ignore line: [Using built-in specs.]
- ignore line: [COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe]
- ignore line: [Target: x86_64-w64-mingw32]
- ignore line: [Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends]
- ignore line: [Thread model: posix]
- ignore line: [Supported LTO compression algorithms: zlib]
- ignore line: [gcc version 13.1.0 (GCC) ]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/']
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/cc1plus.exe -quiet -v -iprefix C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/ -D_REENTRANT C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXCompilerABI.cpp -quiet -dumpdir CMakeFiles/cmTC_38c76.dir/ -dumpbase CMakeCXXCompilerABI.cpp.cpp -dumpbase-ext .cpp -mtune=generic -march=nocona -version -fdiagnostics-color=always -o C:\\Users\\csand\\AppData\\Local\\Temp\\ccUtd0Pk.s]
- ignore line: [GNU C++17 (GCC) version 13.1.0 (x86_64-w64-mingw32)]
- ignore line: [ compiled by GNU C version 13.1.0 GMP version 6.2.1 MPFR version 4.2.0-p4 MPC version 1.3.1 isl version none]
- ignore line: [GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include"]
- ignore line: [ignoring nonexistent directory "/win/include"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../include"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed"]
- ignore line: [ignoring duplicate directory "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/../../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include"]
- ignore line: [ignoring nonexistent directory "/mingw/include"]
- ignore line: [#include "..." search starts here:]
- ignore line: [#include <...> search starts here:]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/x86_64-w64-mingw32]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include/c++/backward]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../include]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/include-fixed]
- ignore line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/include]
- ignore line: [End of search list.]
- ignore line: [Compiler executable checksum: e75de627edc3c57e31324b930b15b056]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/']
- ignore line: [ as -v -o CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj C:\\Users\\csand\\AppData\\Local\\Temp\\ccUtd0Pk.s]
- ignore line: [GNU assembler version 2.40 (x86_64-w64-mingw32) using BFD version (GNU Binutils) 2.40]
- ignore line: [COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/]
- ignore line: [LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../]
- ignore line: [COLLECT_GCC_OPTIONS='-fdiagnostics-color=always' '-v' '-o' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj' '-c' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.'\x0d]
- ignore line: [[2/2] C:\\WINDOWS\\system32\\cmd.exe /C "cd . && C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe -v -Wl -v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj -o cmTC_38c76.exe -Wl --out-implib libcmTC_38c76.dll.a -Wl --major-image-version 0 --minor-image-version 0 && cd ."]
- ignore line: [Using built-in specs.]
- ignore line: [COLLECT_GCC=C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin\\g++.exe]
- ignore line: [COLLECT_LTO_WRAPPER=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/lto-wrapper.exe]
- ignore line: [Target: x86_64-w64-mingw32]
- ignore line: [Configured with: ../gcc-13.1.0/configure --host=x86_64-w64-mingw32 --target=x86_64-w64-mingw32 --build=x86_64-alpine-linux-musl --prefix=/win --enable-checking=release --enable-fully-dynamic-string --enable-languages=c,c++ --with-arch=nocona --with-tune=generic --enable-libatomic --enable-libgomp --enable-libstdcxx-filesystem-ts --enable-libstdcxx-time --enable-seh-exceptions --enable-shared --enable-static --enable-threads=posix --enable-version-specific-runtime-libs --disable-bootstrap --disable-graphite --disable-libada --disable-libstdcxx-pch --disable-libstdcxx-debug --disable-libquadmath --disable-lto --disable-nls --disable-multilib --disable-rpath --disable-symvers --disable-werror --disable-win32-registry --with-gnu-as --with-gnu-ld --with-system-libiconv --with-system-libz --with-gmp=/win/makedepends --with-mpfr=/win/makedepends --with-mpc=/win/makedepends]
- ignore line: [Thread model: posix]
- ignore line: [Supported LTO compression algorithms: zlib]
- ignore line: [gcc version 13.1.0 (GCC) ]
- ignore line: [COMPILER_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/]
- ignore line: [LIBRARY_PATH=C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/]
- ignore line: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../]
- ignore line: [COLLECT_GCC_OPTIONS='-v' '-o' 'cmTC_38c76.exe' '-shared-libgcc' '-mtune=generic' '-march=nocona' '-dumpdir' 'cmTC_38c76.']
- link line: [ C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe -m i386pep -Bdynamic -o cmTC_38c76.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj --out-implib libcmTC_38c76.dll.a --major-image-version 0 --minor-image-version 0 -lstdc++ -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../libexec/gcc/x86_64-w64-mingw32/13.1.0/collect2.exe] ==> ignore
- arg [-m] ==> ignore
- arg [i386pep] ==> ignore
- arg [-Bdynamic] ==> search dynamic
- arg [-o] ==> ignore
- arg [cmTC_38c76.exe] ==> ignore
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib]
- arg [-LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..] ==> dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..]
- arg [-v] ==> ignore
- arg [CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj] ==> ignore
- arg [--out-implib] ==> ignore
- arg [libcmTC_38c76.dll.a] ==> ignore
- arg [--major-image-version] ==> ignore
- arg [0] ==> ignore
- arg [--minor-image-version] ==> ignore
- arg [0] ==> ignore
- arg [-lstdc++] ==> lib [stdc++]
- arg [-lmingw32] ==> lib [mingw32]
- arg [-lgcc_s] ==> lib [gcc_s]
- arg [-lgcc] ==> lib [gcc]
- arg [-lmoldname] ==> lib [moldname]
- arg [-lmingwex] ==> lib [mingwex]
- arg [-lmsvcrt] ==> lib [msvcrt]
- arg [-lkernel32] ==> lib [kernel32]
- arg [-lpthread] ==> lib [pthread]
- arg [-ladvapi32] ==> lib [advapi32]
- arg [-lshell32] ==> lib [shell32]
- arg [-luser32] ==> lib [user32]
- arg [-lkernel32] ==> lib [kernel32]
- arg [-liconv] ==> lib [iconv]
- arg [-lmingw32] ==> lib [mingw32]
- arg [-lgcc_s] ==> lib [gcc_s]
- arg [-lgcc] ==> lib [gcc]
- arg [-lmoldname] ==> lib [moldname]
- arg [-lmingwex] ==> lib [mingwex]
- arg [-lmsvcrt] ==> lib [msvcrt]
- arg [-lkernel32] ==> lib [kernel32]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o]
- arg [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o] ==> obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- ignore line: [collect2 version 13.1.0]
- ignore line: [C:\\Users\\csand\\AppData\\Local\\Programs\\CLion\\bin\\mingw\\bin/ld.exe -m i386pep -Bdynamic -o cmTC_38c76.exe C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0 -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib -LC:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../.. -v CMakeFiles/cmTC_38c76.dir/CMakeCXXCompilerABI.cpp.obj --out-implib libcmTC_38c76.dll.a --major-image-version 0 --minor-image-version 0 -lstdc++ -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 -lpthread -ladvapi32 -lshell32 -luser32 -lkernel32 -liconv -lmingw32 -lgcc_s -lgcc -lmoldname -lmingwex -lmsvcrt -lkernel32 C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- linker tool for 'CXX': C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe
- remove lib [msvcrt]
- remove lib [msvcrt]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/crt2.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/crt2.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib/default-manifest.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/default-manifest.o]
- collapse obj [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib/../lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../../../x86_64-w64-mingw32/lib] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib]
- collapse library dir [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/../lib/gcc/x86_64-w64-mingw32/13.1.0/../../..] ==> [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- implicit libs: [stdc++;mingw32;gcc_s;gcc;moldname;mingwex;kernel32;pthread;advapi32;shell32;user32;kernel32;iconv;mingw32;gcc_s;gcc;moldname;mingwex;kernel32]
- implicit objs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/crt2.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtbegin.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib/default-manifest.o;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0/crtend.o]
- implicit dirs: [C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc/x86_64-w64-mingw32/13.1.0;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib/gcc;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/x86_64-w64-mingw32/lib;C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/lib]
- implicit fwks: []
-
-
- -
- kind: "message-v1"
- backtrace:
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeDetermineLinkerId.cmake:36 (message)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeDetermineCompilerABI.cmake:270 (cmake_determine_linker_id)"
- - "C:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeTestCXXCompiler.cmake:26 (CMAKE_DETERMINE_COMPILER_ABI)"
- - "CMakeLists.txt:2 (project)"
- message: |
- Running the CXX compiler's linker: "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/ld.exe" "-v"
- GNU ld (GNU Binutils) 2.40
-...
diff --git a/assignment1/cmake-build-debug/CMakeFiles/InstallScripts.json b/assignment1/cmake-build-debug/CMakeFiles/InstallScripts.json
deleted file mode 100644
index d63ef73..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/InstallScripts.json
+++ /dev/null
@@ -1,7 +0,0 @@
-{
- "InstallScripts" :
- [
- "C:/Users/csand/IKT203/assignment1/cmake-build-debug/cmake_install.cmake"
- ],
- "Parallel" : false
-}
diff --git a/assignment1/cmake-build-debug/CMakeFiles/TargetDirectories.txt b/assignment1/cmake-build-debug/CMakeFiles/TargetDirectories.txt
deleted file mode 100644
index b55f890..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/TargetDirectories.txt
+++ /dev/null
@@ -1,3 +0,0 @@
-C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/assignment1.dir
-C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/edit_cache.dir
-C:/Users/csand/IKT203/assignment1/cmake-build-debug/CMakeFiles/rebuild_cache.dir
diff --git a/assignment1/cmake-build-debug/CMakeFiles/clion-Debug-log.txt b/assignment1/cmake-build-debug/CMakeFiles/clion-Debug-log.txt
deleted file mode 100644
index cabf286..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/clion-Debug-log.txt
+++ /dev/null
@@ -1,4 +0,0 @@
-C:\Users\csand\AppData\Local\Programs\CLion\bin\cmake\win\x64\bin\cmake.exe -DCMAKE_BUILD_TYPE=Debug -DCMAKE_MAKE_PROGRAM=C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe -G Ninja -S C:\Users\csand\IKT203\assignment1 -B C:\Users\csand\IKT203\assignment1\cmake-build-debug
--- Configuring done (0.5s)
--- Generating done (0.0s)
--- Build files have been written to: C:/Users/csand/IKT203/assignment1/cmake-build-debug
diff --git a/assignment1/cmake-build-debug/CMakeFiles/clion-environment.txt b/assignment1/cmake-build-debug/CMakeFiles/clion-environment.txt
deleted file mode 100644
index a30c6f6..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/clion-environment.txt
+++ /dev/null
@@ -1,5 +0,0 @@
-ToolSet: 11.0 w64 (local)@C:\Users\csand\AppData\Local\Programs\CLion\bin\mingw
-Ninja: 1.12.1@C:\Users\csand\AppData\Local\Programs\CLion\bin\ninja\win\x64\ninja.exe
-Options:
-
-Options:-DCMAKE_MAKE_PROGRAM=C:/Users/csand/AppData/Local/Programs/CLion/bin/ninja/win/x64/ninja.exe
\ No newline at end of file
diff --git a/assignment1/cmake-build-debug/CMakeFiles/cmake.check_cache b/assignment1/cmake-build-debug/CMakeFiles/cmake.check_cache
deleted file mode 100644
index 3dccd73..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/cmake.check_cache
+++ /dev/null
@@ -1 +0,0 @@
-# This file is generated by cmake for dependency checking of the CMakeCache.txt file
diff --git a/assignment1/cmake-build-debug/CMakeFiles/rules.ninja b/assignment1/cmake-build-debug/CMakeFiles/rules.ninja
deleted file mode 100644
index 8f77395..0000000
--- a/assignment1/cmake-build-debug/CMakeFiles/rules.ninja
+++ /dev/null
@@ -1,64 +0,0 @@
-# CMAKE generated file: DO NOT EDIT!
-# Generated by "Ninja" Generator, CMake Version 4.0
-
-# This file contains all the rules used to get the outputs files
-# built from the input files.
-# It is included in the main 'build.ninja'.
-
-# =============================================================================
-# Project: assignment1
-# Configurations: Debug
-# =============================================================================
-# =============================================================================
-
-#############################################
-# Rule for compiling CXX files.
-
-rule CXX_COMPILER__assignment1_unscanned_Debug
- depfile = $DEP_FILE
- deps = gcc
- command = ${LAUNCHER}${CODE_CHECK}C:\Users\csand\AppData\Local\Programs\CLion\bin\mingw\bin\g++.exe $DEFINES $INCLUDES $FLAGS -MD -MT $out -MF $DEP_FILE -o $out -c $in
- description = Building CXX object $out
-
-
-#############################################
-# Rule for linking CXX executable.
-
-rule CXX_EXECUTABLE_LINKER__assignment1_Debug
- command = C:\WINDOWS\system32\cmd.exe /C "$PRE_LINK && C:\Users\csand\AppData\Local\Programs\CLion\bin\mingw\bin\g++.exe $FLAGS $LINK_FLAGS $in -o $TARGET_FILE -Wl,--out-implib,$TARGET_IMPLIB -Wl,--major-image-version,0,--minor-image-version,0 $LINK_PATH $LINK_LIBRARIES && $POST_BUILD"
- description = Linking CXX executable $TARGET_FILE
- restat = $RESTAT
-
-
-#############################################
-# Rule for running custom commands.
-
-rule CUSTOM_COMMAND
- command = $COMMAND
- description = $DESC
-
-
-#############################################
-# Rule for re-running cmake.
-
-rule RERUN_CMAKE
- command = C:\Users\csand\AppData\Local\Programs\CLion\bin\cmake\win\x64\bin\cmake.exe --regenerate-during-build -SC:\Users\csand\IKT203\assignment1 -BC:\Users\csand\IKT203\assignment1\cmake-build-debug
- description = Re-running CMake...
- generator = 1
-
-
-#############################################
-# Rule for cleaning all built files.
-
-rule CLEAN
- command = C:\Users\csand\AppData\Local\Programs\CLion\bin\ninja\win\x64\ninja.exe $FILE_ARG -t clean $TARGETS
- description = Cleaning all built files...
-
-
-#############################################
-# Rule for printing all primary targets available.
-
-rule HELP
- command = C:\Users\csand\AppData\Local\Programs\CLion\bin\ninja\win\x64\ninja.exe -t targets
- description = All primary targets available:
-
diff --git a/assignment1/cmake-build-debug/Testing/Temporary/LastTest.log b/assignment1/cmake-build-debug/Testing/Temporary/LastTest.log
deleted file mode 100644
index 6a101d7..0000000
--- a/assignment1/cmake-build-debug/Testing/Temporary/LastTest.log
+++ /dev/null
@@ -1,3 +0,0 @@
-Start testing: Oct 18 13:54 W. Europe Summer Time
-----------------------------------------------------------
-End testing: Oct 18 13:54 W. Europe Summer Time
diff --git a/assignment1/cmake-build-debug/build.ninja b/assignment1/cmake-build-debug/build.ninja
deleted file mode 100644
index d5bd9ae..0000000
--- a/assignment1/cmake-build-debug/build.ninja
+++ /dev/null
@@ -1,176 +0,0 @@
-# CMAKE generated file: DO NOT EDIT!
-# Generated by "Ninja" Generator, CMake Version 4.0
-
-# This file contains all the build statements describing the
-# compilation DAG.
-
-# =============================================================================
-# Write statements declared in CMakeLists.txt:
-#
-# Which is the root file.
-# =============================================================================
-
-# =============================================================================
-# Project: assignment1
-# Configurations: Debug
-# =============================================================================
-
-#############################################
-# Minimal version of Ninja required by this file
-
-ninja_required_version = 1.5
-
-
-#############################################
-# Set configuration variable for custom commands.
-
-CONFIGURATION = Debug
-# =============================================================================
-# Include auxiliary files.
-
-
-#############################################
-# Include rules file.
-
-include CMakeFiles/rules.ninja
-
-# =============================================================================
-
-#############################################
-# Logical path to working directory; prefix for absolute paths.
-
-cmake_ninja_workdir = C$:/Users/csand/IKT203/assignment1/cmake-build-debug/
-# =============================================================================
-# Object build statements for EXECUTABLE target assignment1
-
-
-#############################################
-# Order-only phony target for assignment1
-
-build cmake_object_order_depends_target_assignment1: phony || .
-
-build CMakeFiles/assignment1.dir/main.cpp.obj: CXX_COMPILER__assignment1_unscanned_Debug C$:/Users/csand/IKT203/assignment1/main.cpp || cmake_object_order_depends_target_assignment1
- CONFIG = Debug
- DEP_FILE = CMakeFiles\assignment1.dir\main.cpp.obj.d
- FLAGS = -g -std=gnu++20 -fdiagnostics-color=always
- OBJECT_DIR = CMakeFiles\assignment1.dir
- OBJECT_FILE_DIR = CMakeFiles\assignment1.dir
-
-build CMakeFiles/assignment1.dir/TMovie.cpp.obj: CXX_COMPILER__assignment1_unscanned_Debug C$:/Users/csand/IKT203/assignment1/TMovie.cpp || cmake_object_order_depends_target_assignment1
- CONFIG = Debug
- DEP_FILE = CMakeFiles\assignment1.dir\TMovie.cpp.obj.d
- FLAGS = -g -std=gnu++20 -fdiagnostics-color=always
- OBJECT_DIR = CMakeFiles\assignment1.dir
- OBJECT_FILE_DIR = CMakeFiles\assignment1.dir
-
-build CMakeFiles/assignment1.dir/TMovieList.cpp.obj: CXX_COMPILER__assignment1_unscanned_Debug C$:/Users/csand/IKT203/assignment1/TMovieList.cpp || cmake_object_order_depends_target_assignment1
- CONFIG = Debug
- DEP_FILE = CMakeFiles\assignment1.dir\TMovieList.cpp.obj.d
- FLAGS = -g -std=gnu++20 -fdiagnostics-color=always
- OBJECT_DIR = CMakeFiles\assignment1.dir
- OBJECT_FILE_DIR = CMakeFiles\assignment1.dir
-
-build CMakeFiles/assignment1.dir/TMovieNode.cpp.obj: CXX_COMPILER__assignment1_unscanned_Debug C$:/Users/csand/IKT203/assignment1/TMovieNode.cpp || cmake_object_order_depends_target_assignment1
- CONFIG = Debug
- DEP_FILE = CMakeFiles\assignment1.dir\TMovieNode.cpp.obj.d
- FLAGS = -g -std=gnu++20 -fdiagnostics-color=always
- OBJECT_DIR = CMakeFiles\assignment1.dir
- OBJECT_FILE_DIR = CMakeFiles\assignment1.dir
-
-
-# =============================================================================
-# Link build statements for EXECUTABLE target assignment1
-
-
-#############################################
-# Link the executable assignment1.exe
-
-build assignment1.exe: CXX_EXECUTABLE_LINKER__assignment1_Debug CMakeFiles/assignment1.dir/main.cpp.obj CMakeFiles/assignment1.dir/TMovie.cpp.obj CMakeFiles/assignment1.dir/TMovieList.cpp.obj CMakeFiles/assignment1.dir/TMovieNode.cpp.obj
- CONFIG = Debug
- FLAGS = -g
- LINK_LIBRARIES = -lkernel32 -luser32 -lgdi32 -lwinspool -lshell32 -lole32 -loleaut32 -luuid -lcomdlg32 -ladvapi32
- OBJECT_DIR = CMakeFiles\assignment1.dir
- POST_BUILD = cd .
- PRE_LINK = cd .
- TARGET_FILE = assignment1.exe
- TARGET_IMPLIB = libassignment1.dll.a
- TARGET_PDB = assignment1.exe.dbg
-
-
-#############################################
-# Utility command for edit_cache
-
-build CMakeFiles/edit_cache.util: CUSTOM_COMMAND
- COMMAND = C:\WINDOWS\system32\cmd.exe /C "cd /D C:\Users\csand\IKT203\assignment1\cmake-build-debug && C:\Users\csand\AppData\Local\Programs\CLion\bin\cmake\win\x64\bin\cmake.exe -E echo "No interactive CMake dialog available.""
- DESC = No interactive CMake dialog available...
- restat = 1
-
-build edit_cache: phony CMakeFiles/edit_cache.util
-
-
-#############################################
-# Utility command for rebuild_cache
-
-build CMakeFiles/rebuild_cache.util: CUSTOM_COMMAND
- COMMAND = C:\WINDOWS\system32\cmd.exe /C "cd /D C:\Users\csand\IKT203\assignment1\cmake-build-debug && C:\Users\csand\AppData\Local\Programs\CLion\bin\cmake\win\x64\bin\cmake.exe --regenerate-during-build -SC:\Users\csand\IKT203\assignment1 -BC:\Users\csand\IKT203\assignment1\cmake-build-debug"
- DESC = Running CMake to regenerate build system...
- pool = console
- restat = 1
-
-build rebuild_cache: phony CMakeFiles/rebuild_cache.util
-
-# =============================================================================
-# Target aliases.
-
-build assignment1: phony assignment1.exe
-
-# =============================================================================
-# Folder targets.
-
-# =============================================================================
-
-#############################################
-# Folder: C:/Users/csand/IKT203/assignment1/cmake-build-debug
-
-build codegen: phony
-
-# =============================================================================
-
-#############################################
-# Folder: C:/Users/csand/IKT203/assignment1/cmake-build-debug
-
-build all: phony assignment1.exe
-
-# =============================================================================
-# Built-in targets
-
-
-#############################################
-# Re-run CMake if any of its inputs changed.
-
-build build.ninja C$:/Users/csand/IKT203/assignment1/cmake-build-debug/cmake_install.cmake: RERUN_CMAKE | C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCommonLanguageInclude.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeGenericSystem.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeInitializeConfigs.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeLanguageInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeRCInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInitialize.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/CMakeCommonCompilerMacros.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCXXLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCommonLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C-ABI.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX-ABI.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-Initialize.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-windres.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/WindowsPaths.cmake C$:/Users/csand/IKT203/assignment1/CMakeLists.txt CMakeCache.txt CMakeFiles/4.0.2/CMakeCCompiler.cmake CMakeFiles/4.0.2/CMakeCXXCompiler.cmake CMakeFiles/4.0.2/CMakeRCCompiler.cmake CMakeFiles/4.0.2/CMakeSystem.cmake
- pool = console
-
-
-#############################################
-# A missing CMake input file is not an error.
-
-build C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCXXInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeCommonLanguageInclude.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeGenericSystem.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeInitializeConfigs.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeLanguageInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeRCInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/CMakeSystemSpecificInitialize.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/CMakeCommonCompilerMacros.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Compiler/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCXXLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Internal/CMakeCommonLinkerInformation.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Linker/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Linker/Windows-GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C-ABI.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-C.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX-ABI.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU-CXX.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-GNU.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-Initialize.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows-windres.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/Windows.cmake C$:/Users/csand/AppData/Local/Programs/CLion/bin/cmake/win/x64/share/cmake-4.0/Modules/Platform/WindowsPaths.cmake C$:/Users/csand/IKT203/assignment1/CMakeLists.txt CMakeCache.txt CMakeFiles/4.0.2/CMakeCCompiler.cmake CMakeFiles/4.0.2/CMakeCXXCompiler.cmake CMakeFiles/4.0.2/CMakeRCCompiler.cmake CMakeFiles/4.0.2/CMakeSystem.cmake: phony
-
-
-#############################################
-# Clean all the built files.
-
-build clean: CLEAN
-
-
-#############################################
-# Print all primary targets available.
-
-build help: HELP
-
-
-#############################################
-# Make the all target the default.
-
-default all
diff --git a/assignment1/cmake-build-debug/cmake_install.cmake b/assignment1/cmake-build-debug/cmake_install.cmake
deleted file mode 100644
index c004c82..0000000
--- a/assignment1/cmake-build-debug/cmake_install.cmake
+++ /dev/null
@@ -1,61 +0,0 @@
-# Install script for directory: C:/Users/csand/IKT203/assignment1
-
-# Set the install prefix
-if(NOT DEFINED CMAKE_INSTALL_PREFIX)
- set(CMAKE_INSTALL_PREFIX "C:/Program Files (x86)/assignment1")
-endif()
-string(REGEX REPLACE "/$" "" CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}")
-
-# Set the install configuration name.
-if(NOT DEFINED CMAKE_INSTALL_CONFIG_NAME)
- if(BUILD_TYPE)
- string(REGEX REPLACE "^[^A-Za-z0-9_]+" ""
- CMAKE_INSTALL_CONFIG_NAME "${BUILD_TYPE}")
- else()
- set(CMAKE_INSTALL_CONFIG_NAME "Debug")
- endif()
- message(STATUS "Install configuration: \"${CMAKE_INSTALL_CONFIG_NAME}\"")
-endif()
-
-# Set the component getting installed.
-if(NOT CMAKE_INSTALL_COMPONENT)
- if(COMPONENT)
- message(STATUS "Install component: \"${COMPONENT}\"")
- set(CMAKE_INSTALL_COMPONENT "${COMPONENT}")
- else()
- set(CMAKE_INSTALL_COMPONENT)
- endif()
-endif()
-
-# Is this installation the result of a crosscompile?
-if(NOT DEFINED CMAKE_CROSSCOMPILING)
- set(CMAKE_CROSSCOMPILING "FALSE")
-endif()
-
-# Set path to fallback-tool for dependency-resolution.
-if(NOT DEFINED CMAKE_OBJDUMP)
- set(CMAKE_OBJDUMP "C:/Users/csand/AppData/Local/Programs/CLion/bin/mingw/bin/objdump.exe")
-endif()
-
-string(REPLACE ";" "\n" CMAKE_INSTALL_MANIFEST_CONTENT
- "${CMAKE_INSTALL_MANIFEST_FILES}")
-if(CMAKE_INSTALL_LOCAL_ONLY)
- file(WRITE "C:/Users/csand/IKT203/assignment1/cmake-build-debug/install_local_manifest.txt"
- "${CMAKE_INSTALL_MANIFEST_CONTENT}")
-endif()
-if(CMAKE_INSTALL_COMPONENT)
- if(CMAKE_INSTALL_COMPONENT MATCHES "^[a-zA-Z0-9_.+-]+$")
- set(CMAKE_INSTALL_MANIFEST "install_manifest_${CMAKE_INSTALL_COMPONENT}.txt")
- else()
- string(MD5 CMAKE_INST_COMP_HASH "${CMAKE_INSTALL_COMPONENT}")
- set(CMAKE_INSTALL_MANIFEST "install_manifest_${CMAKE_INST_COMP_HASH}.txt")
- unset(CMAKE_INST_COMP_HASH)
- endif()
-else()
- set(CMAKE_INSTALL_MANIFEST "install_manifest.txt")
-endif()
-
-if(NOT CMAKE_INSTALL_LOCAL_ONLY)
- file(WRITE "C:/Users/csand/IKT203/assignment1/cmake-build-debug/${CMAKE_INSTALL_MANIFEST}"
- "${CMAKE_INSTALL_MANIFEST_CONTENT}")
-endif()
diff --git a/assignment1/main.cpp b/assignment1/main.cpp
deleted file mode 100644
index de37b87..0000000
--- a/assignment1/main.cpp
+++ /dev/null
@@ -1,32 +0,0 @@
-#include
-#include "TMovieList.h"
-
-// specialised versions of SearchFor() from TMovieList
-bool SearchByTitle(const TMovie* m, void* c)
-{
- const auto* title = static_cast(c);
- return m->GetTitle() == *title;
-}
-
-bool SearchByDirector(const TMovie* m, void* criteria)
-{
- const auto* director = static_cast(criteria);
- return m->GetDirector() == *director;
-}
-
-bool SearchByGenre(const TMovie* m, void* criteria)
-{
- const auto* genre = static_cast(criteria);
- return m->GetGenre() == *genre;
-}
-
-
-
-
-
-int main()
-{
-
-
-
-}