// File: build.zig // Created Time: 2023-01-07 // Author: sjinzh (sjinzh@gmail.com) const std = @import("std"); // Zig Version: 0.10.0 // Build Command: zig build pub fn build(b: *std.build.Builder) void { const target = b.standardTargetOptions(.{}); const mode = b.standardReleaseOptions(); // Section: "Time Complexity" // Source File: "chapter_computational_complexity/time_complexity.zig" // Run Command: zig build run_time_complexity const exe_time_complexity = b.addExecutable("time_complexity", "chapter_computational_complexity/time_complexity.zig"); exe_time_complexity.addPackagePath("include", "include/include.zig"); exe_time_complexity.setTarget(target); exe_time_complexity.setBuildMode(mode); exe_time_complexity.install(); const run_cmd_time_complexity = exe_time_complexity.run(); run_cmd_time_complexity.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_time_complexity.addArgs(args); const run_step_time_complexity = b.step("run_time_complexity", "Run time_complexity"); run_step_time_complexity.dependOn(&run_cmd_time_complexity.step); // Source File: "chapter_computational_complexity/worst_best_time_complexity.zig" // Run Command: zig build run_worst_best_time_complexity const exe_worst_best_time_complexity = b.addExecutable("worst_best_time_complexity", "chapter_computational_complexity/worst_best_time_complexity.zig"); exe_worst_best_time_complexity.addPackagePath("include", "include/include.zig"); exe_worst_best_time_complexity.setTarget(target); exe_worst_best_time_complexity.setBuildMode(mode); exe_worst_best_time_complexity.install(); const run_cmd_worst_best_time_complexity = exe_worst_best_time_complexity.run(); run_cmd_worst_best_time_complexity.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_worst_best_time_complexity.addArgs(args); const run_step_worst_best_time_complexity = b.step("run_worst_best_time_complexity", "Run worst_best_time_complexity"); run_step_worst_best_time_complexity.dependOn(&run_cmd_worst_best_time_complexity.step); // Section: "Space Complexity" // Source File: "chapter_computational_complexity/space_complexity.zig" // Run Command: zig build run_space_complexity const exe_space_complexity = b.addExecutable("space_complexity", "chapter_computational_complexity/space_complexity.zig"); exe_space_complexity.addPackagePath("include", "include/include.zig"); exe_space_complexity.setTarget(target); exe_space_complexity.setBuildMode(mode); exe_space_complexity.install(); const run_cmd_space_complexity = exe_space_complexity.run(); run_cmd_space_complexity.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_space_complexity.addArgs(args); const run_step_space_complexity = b.step("run_space_complexity", "Run space_complexity"); run_step_space_complexity.dependOn(&run_cmd_space_complexity.step); // Section: "Space Time Tradeoff" // Source File: "chapter_computational_complexity/leetcode_two_sum.zig" // Run Command: zig build run_leetcode_two_sum const exe_leetcode_two_sum = b.addExecutable("leetcode_two_sum", "chapter_computational_complexity/leetcode_two_sum.zig"); exe_leetcode_two_sum.addPackagePath("include", "include/include.zig"); exe_leetcode_two_sum.setTarget(target); exe_leetcode_two_sum.setBuildMode(mode); exe_leetcode_two_sum.install(); const run_cmd_leetcode_two_sum = exe_leetcode_two_sum.run(); run_cmd_leetcode_two_sum.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_leetcode_two_sum.addArgs(args); const run_step_leetcode_two_sum = b.step("run_leetcode_two_sum", "Run leetcode_two_sum"); run_step_leetcode_two_sum.dependOn(&run_cmd_leetcode_two_sum.step); // Section: "Array" // Source File: "chapter_array_and_linkedlist/array.zig" // Run Command: zig build run_array const exe_array = b.addExecutable("array", "chapter_array_and_linkedlist/array.zig"); exe_array.addPackagePath("include", "include/include.zig"); exe_array.setTarget(target); exe_array.setBuildMode(mode); exe_array.install(); const run_cmd_array = exe_array.run(); run_cmd_array.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_array.addArgs(args); const run_step_array = b.step("run_array", "Run array"); run_step_array.dependOn(&run_cmd_array.step); // Section: "LinkedList" // Source File: "chapter_array_and_linkedlist/linked_list.zig" // Run Command: zig build run_linked_list const exe_linked_list = b.addExecutable("linked_list", "chapter_array_and_linkedlist/linked_list.zig"); exe_linked_list.addPackagePath("include", "include/include.zig"); exe_linked_list.setTarget(target); exe_linked_list.setBuildMode(mode); exe_linked_list.install(); const run_cmd_linked_list = exe_linked_list.run(); run_cmd_linked_list.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_linked_list.addArgs(args); const run_step_linked_list = b.step("run_linked_list", "Run linked_list"); run_step_linked_list.dependOn(&run_cmd_linked_list.step); // Section: "List" // Source File: "chapter_array_and_linkedlist/list.zig" // Run Command: zig build run_list const exe_list = b.addExecutable("list", "chapter_array_and_linkedlist/list.zig"); exe_list.addPackagePath("include", "include/include.zig"); exe_list.setTarget(target); exe_list.setBuildMode(mode); exe_list.install(); const run_cmd_list = exe_list.run(); run_cmd_list.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_list.addArgs(args); const run_step_list = b.step("run_list", "Run list"); run_step_list.dependOn(&run_cmd_list.step); // Source File: "chapter_array_and_linkedlist/my_list.zig" // Run Command: zig build run_my_list const exe_my_list = b.addExecutable("my_list", "chapter_array_and_linkedlist/my_list.zig"); exe_my_list.addPackagePath("include", "include/include.zig"); exe_my_list.setTarget(target); exe_my_list.setBuildMode(mode); exe_my_list.install(); const run_cmd_my_list = exe_my_list.run(); run_cmd_my_list.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_my_list.addArgs(args); const run_step_my_list = b.step("run_my_list", "Run my_list"); run_step_my_list.dependOn(&run_cmd_my_list.step); // Section: "Stack" // Source File: "chapter_stack_and_queue/stack.zig" // Run Command: zig build run_stack const exe_stack = b.addExecutable("stack", "chapter_stack_and_queue/stack.zig"); exe_stack.addPackagePath("include", "include/include.zig"); exe_stack.setTarget(target); exe_stack.setBuildMode(mode); exe_stack.install(); const run_cmd_stack = exe_stack.run(); run_cmd_stack.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_stack.addArgs(args); const run_step_stack = b.step("run_stack", "Run stack"); run_step_stack.dependOn(&run_cmd_stack.step); // Source File: "chapter_stack_and_queue/linkedlist_stack.zig" // Run Command: zig build run_linkedlist_stack const exe_linkedlist_stack = b.addExecutable("linkedlist_stack", "chapter_stack_and_queue/linkedlist_stack.zig"); exe_linkedlist_stack.addPackagePath("include", "include/include.zig"); exe_linkedlist_stack.setTarget(target); exe_linkedlist_stack.setBuildMode(mode); exe_linkedlist_stack.install(); const run_cmd_linkedlist_stack = exe_linkedlist_stack.run(); run_cmd_linkedlist_stack.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_linkedlist_stack.addArgs(args); const run_step_linkedlist_stack = b.step("run_linkedlist_stack", "Run linkedlist_stack"); run_step_linkedlist_stack.dependOn(&run_cmd_linkedlist_stack.step); // Source File: "chapter_stack_and_queue/array_stack.zig" // Run Command: zig build run_array_stack const exe_array_stack = b.addExecutable("array_stack", "chapter_stack_and_queue/array_stack.zig"); exe_array_stack.addPackagePath("include", "include/include.zig"); exe_array_stack.setTarget(target); exe_array_stack.setBuildMode(mode); exe_array_stack.install(); const run_cmd_array_stack = exe_linkedlist_stack.run(); run_cmd_array_stack.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_array_stack.addArgs(args); const run_step_array_stack = b.step("run_array_stack", "Run array_stack"); run_step_array_stack.dependOn(&run_cmd_array_stack.step); // Section: "Hash Map" // Source File: "chapter_hashing/hash_map.zig" // Run Command: zig build run_hash_map const exe_hash_map = b.addExecutable("hash_map", "chapter_hashing/hash_map.zig"); exe_hash_map.addPackagePath("include", "include/include.zig"); exe_hash_map.setTarget(target); exe_hash_map.setBuildMode(mode); exe_hash_map.install(); const run_cmd_hash_map = exe_hash_map.run(); run_cmd_hash_map.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_hash_map.addArgs(args); const run_step_hash_map= b.step("run_hash_map", "Run hash_map"); run_step_hash_map.dependOn(&run_cmd_hash_map.step); // Source File: "chapter_hashing/array_hash_map.zig" // Run Command: zig build run_array_hash_map const exe_array_hash_map = b.addExecutable("array_hash_map", "chapter_hashing/array_hash_map.zig"); exe_array_hash_map.addPackagePath("include", "include/include.zig"); exe_array_hash_map.setTarget(target); exe_array_hash_map.setBuildMode(mode); exe_array_hash_map.install(); const run_cmd_array_hash_map = exe_array_hash_map.run(); run_cmd_array_hash_map.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_array_hash_map.addArgs(args); const run_step_array_hash_map= b.step("run_array_hash_map", "Run array_hash_map"); run_step_array_hash_map.dependOn(&run_cmd_array_hash_map.step); // Section: "Binary Tree" // Source File: "chapter_tree/binary_tree.zig" // Run Command: zig build run_binary_tree const exe_binary_tree = b.addExecutable("hash_map", "chapter_tree/binary_tree.zig"); exe_binary_tree.addPackagePath("include", "include/include.zig"); exe_binary_tree.setTarget(target); exe_binary_tree.setBuildMode(mode); exe_binary_tree.install(); const run_cmd_binary_tree = exe_binary_tree.run(); run_cmd_binary_tree.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_binary_tree.addArgs(args); const run_step_binary_tree= b.step("run_binary_tree", "Run binary_tree"); run_step_binary_tree.dependOn(&run_cmd_binary_tree.step); // Section: "Heap" // Source File: "chapter_heap/heap.zig" // Run Command: zig build run_heap const exe_heap = b.addExecutable("heap", "chapter_heap/heap.zig"); exe_heap.addPackagePath("include", "include/include.zig"); exe_heap.setTarget(target); exe_heap.setBuildMode(mode); exe_heap.install(); const run_cmd_heap = exe_heap.run(); run_cmd_heap.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_heap.addArgs(args); const run_step_heap = b.step("run_heap", "Run heap"); run_step_heap.dependOn(&run_cmd_heap.step); // Source File: "chapter_heap/my_heap.zig" // Run Command: zig build run_my_heap const exe_my_heap = b.addExecutable("my_heap", "chapter_heap/my_heap.zig"); exe_my_heap.addPackagePath("include", "include/include.zig"); exe_my_heap.setTarget(target); exe_my_heap.setBuildMode(mode); exe_my_heap.install(); const run_cmd_my_heap = exe_my_heap.run(); run_cmd_my_heap.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_my_heap.addArgs(args); const run_step_my_heap = b.step("run_my_heap", "Run my_heap"); run_step_my_heap.dependOn(&run_cmd_my_heap.step); // Section: "Linear Search" // Source File: "chapter_searching/linear_search.zig" // Run Command: zig build run_linear_search const exe_linear_search = b.addExecutable("linear_search", "chapter_searching/linear_search.zig"); exe_linear_search.addPackagePath("include", "include/include.zig"); exe_linear_search.setTarget(target); exe_linear_search.setBuildMode(mode); exe_linear_search.install(); const run_cmd_linear_search = exe_linear_search.run(); run_cmd_linear_search.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_linear_search.addArgs(args); const run_step_linear_search= b.step("run_linear_search", "Run linear_search"); run_step_linear_search.dependOn(&run_cmd_linear_search.step); // Section: "Binary Search" // Source File: "chapter_searching/binary_search.zig" // Run Command: zig build run_binary_search const exe_binary_search = b.addExecutable("binary_search", "chapter_searching/binary_search.zig"); exe_binary_search.addPackagePath("include", "include/include.zig"); exe_binary_search.setTarget(target); exe_binary_search.setBuildMode(mode); exe_binary_search.install(); const run_cmd_binary_search = exe_binary_search.run(); run_cmd_binary_search.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_binary_search.addArgs(args); const run_step_binary_search= b.step("run_binary_search", "Run binary_search"); run_step_binary_search.dependOn(&run_cmd_binary_search.step); // Section: "Hash Search" // Source File: "chapter_searching/hashing_search.zig" // Run Command: zig build run_hashing_search const exe_hashing_search = b.addExecutable("hashing_search", "chapter_searching/hashing_search.zig"); exe_hashing_search.addPackagePath("include", "include/include.zig"); exe_hashing_search.setTarget(target); exe_hashing_search.setBuildMode(mode); exe_hashing_search.install(); const run_cmd_hashing_search = exe_hashing_search.run(); run_cmd_hashing_search.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_hashing_search.addArgs(args); const run_step_hashing_search= b.step("run_hashing_search", "Run hashing_search"); run_step_hashing_search.dependOn(&run_cmd_hashing_search.step); // Section: "Bubble Sort" // Source File: "chapter_sorting/bubble_sort.zig" // Run Command: zig build run_bubble_sort const exe_bubble_sort = b.addExecutable("bubble_sort", "chapter_sorting/bubble_sort.zig"); exe_bubble_sort.addPackagePath("include", "include/include.zig"); exe_bubble_sort.setTarget(target); exe_bubble_sort.setBuildMode(mode); exe_bubble_sort.install(); const run_cmd_bubble_sort = exe_bubble_sort.run(); run_cmd_bubble_sort.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_bubble_sort.addArgs(args); const run_step_bubble_sort = b.step("run_bubble_sort", "Run bubble_sort"); run_step_bubble_sort.dependOn(&run_cmd_bubble_sort.step); // Section: "Insertion Sort" // Source File: "chapter_sorting/insertion_sort.zig" // Run Command: zig build run_insertion_sort const exe_insertion_sort = b.addExecutable("insertion_sort", "chapter_sorting/insertion_sort.zig"); exe_insertion_sort.addPackagePath("include", "include/include.zig"); exe_insertion_sort.setTarget(target); exe_insertion_sort.setBuildMode(mode); exe_insertion_sort.install(); const run_cmd_insertion_sort = exe_insertion_sort.run(); run_cmd_insertion_sort.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_insertion_sort.addArgs(args); const run_step_insertion_sort = b.step("run_insertion_sort", "Run insertion_sort"); run_step_insertion_sort.dependOn(&run_cmd_insertion_sort.step); // Section: "Quick Sort" // Source File: "chapter_sorting/quick_sort.zig" // Run Command: zig build run_quick_sort const exe_quick_sort = b.addExecutable("quick_sort", "chapter_sorting/quick_sort.zig"); exe_quick_sort.addPackagePath("include", "include/include.zig"); exe_quick_sort.setTarget(target); exe_quick_sort.setBuildMode(mode); exe_quick_sort.install(); const run_cmd_quick_sort = exe_quick_sort.run(); run_cmd_quick_sort.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_quick_sort.addArgs(args); const run_step_quick_sort = b.step("run_quick_sort", "Run quick_sort"); run_step_quick_sort.dependOn(&run_cmd_quick_sort.step); // Section: "Merge Sort" // Source File: "chapter_sorting/merge_sort.zig" // Run Command: zig build run_merge_sort const exe_merge_sort = b.addExecutable("merge_sort", "chapter_sorting/merge_sort.zig"); exe_merge_sort.addPackagePath("include", "include/include.zig"); exe_merge_sort.setTarget(target); exe_merge_sort.setBuildMode(mode); exe_merge_sort.install(); const run_cmd_merge_sort = exe_merge_sort.run(); run_cmd_merge_sort.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_merge_sort.addArgs(args); const run_step_merge_sort = b.step("run_merge_sort", "Run merge_sort"); run_step_merge_sort.dependOn(&run_cmd_merge_sort.step); // Section: "Radix Sort" // Source File: "chapter_sorting/radix_sort.zig" // Run Command: zig build run_radix_sort const exe_radix_sort = b.addExecutable("radix_sort", "chapter_sorting/radix_sort.zig"); exe_radix_sort.addPackagePath("include", "include/include.zig"); exe_radix_sort.setTarget(target); exe_radix_sort.setBuildMode(mode); exe_radix_sort.install(); const run_cmd_radix_sort = exe_radix_sort.run(); run_cmd_radix_sort.step.dependOn(b.getInstallStep()); if (b.args) |args| run_cmd_radix_sort.addArgs(args); const run_step_radix_sort = b.step("run_radix_sort", "Run radix_sort"); run_step_radix_sort.dependOn(&run_cmd_radix_sort.step); }