aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/parser.cpp14
-rw-r--r--src/thread_pool.cpp12
2 files changed, 18 insertions, 8 deletions
diff --git a/src/parser.cpp b/src/parser.cpp
index 520f123d8..eb006cb24 100644
--- a/src/parser.cpp
+++ b/src/parser.cpp
@@ -4966,14 +4966,12 @@ gb_internal void parser_add_foreign_file_to_process(Parser *p, AstPackage *pkg,
gb_internal AstPackage *try_add_import_path(Parser *p, String const &path, String const &rel_path, TokenPos pos, PackageKind kind = Package_Normal) {
String const FILE_EXT = str_lit(".odin");
- mutex_lock(&p->import_mutex);
- defer (mutex_unlock(&p->import_mutex));
-
- if (string_set_exists(&p->imported_files, path)) {
- return nullptr;
+ MUTEX_GUARD_BLOCK(&p->import_mutex) {
+ if (string_set_exists(&p->imported_files, path)) {
+ return nullptr;
+ }
+ string_set_add(&p->imported_files, path);
}
- string_set_add(&p->imported_files, path);
-
AstPackage *pkg = gb_alloc_item(permanent_allocator(), AstPackage);
pkg->kind = kind;
@@ -4991,8 +4989,8 @@ gb_internal AstPackage *try_add_import_path(Parser *p, String const &path, Strin
fi.is_dir = false;
pkg->is_single_file = true;
- parser_add_file_to_process(p, pkg, fi, pos);
parser_add_package(p, pkg);
+ parser_add_file_to_process(p, pkg, fi, pos);
return pkg;
}
diff --git a/src/thread_pool.cpp b/src/thread_pool.cpp
index 1b3e74fbe..eca4d37ab 100644
--- a/src/thread_pool.cpp
+++ b/src/thread_pool.cpp
@@ -1,14 +1,25 @@
// thread_pool.cpp
+struct WorkerTask;
+struct ThreadPool;
+
#define WORKER_TASK_PROC(name) isize name(void *data)
typedef WORKER_TASK_PROC(WorkerTaskProc);
+gb_internal void thread_pool_init(ThreadPool *pool, gbAllocator const &a, isize thread_count, char const *worker_name);
+gb_internal void thread_pool_destroy(ThreadPool *pool);
+gb_internal bool thread_pool_add_task(ThreadPool *pool, WorkerTaskProc *proc, void *data);
+gb_internal void thread_pool_wait(ThreadPool *pool);
+
+
struct WorkerTask {
WorkerTask * next;
WorkerTaskProc *do_work;
void * data;
+ ThreadPool * pool;
};
+
struct ThreadPool {
gbAllocator allocator;
BlockingMutex mutex;
@@ -89,6 +100,7 @@ gb_internal bool thread_pool_add_task(ThreadPool *pool, WorkerTaskProc *proc, vo
GB_PANIC("Out of memory");
return false;
}
+ task->pool = pool;
task->do_work = proc;
task->data = data;