:tada
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <assert.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "job_queue.h"
|
||||
|
||||
@@ -17,7 +18,7 @@ int job_queue_init(struct job_queue *job_queue, int capacity) {
|
||||
|
||||
job_queue->capacity = capacity;
|
||||
job_queue->size = 0;
|
||||
job_queue->jobs = malloc(capacity);
|
||||
job_queue->jobs = malloc(sizeof(void*) * capacity);
|
||||
|
||||
pthread_mutex_unlock(&queue_operation);
|
||||
pthread_mutex_unlock(&queue_push);
|
||||
@@ -26,15 +27,10 @@ int job_queue_init(struct job_queue *job_queue, int capacity) {
|
||||
}
|
||||
|
||||
int job_queue_destroy(struct job_queue *job_queue) {
|
||||
printf("esauc\n");
|
||||
pthread_mutex_lock(&queue_destroy);
|
||||
pthread_mutex_lock(&queue_operation);
|
||||
|
||||
printf("esauc\n");
|
||||
//free(job_queue->jobs);
|
||||
printf("esauc\n");
|
||||
//free(job_queue);
|
||||
printf("esauc\n");
|
||||
free(job_queue->jobs);
|
||||
|
||||
pthread_mutex_unlock(&queue_push);
|
||||
pthread_mutex_unlock(&queue_pop);
|
||||
@@ -47,7 +43,7 @@ int job_queue_push(struct job_queue *job_queue, void *data) {
|
||||
pthread_mutex_lock(&queue_push);
|
||||
pthread_mutex_lock(&queue_operation);
|
||||
|
||||
(&job_queue->jobs)[job_queue->size] = data;
|
||||
job_queue->jobs[job_queue->size] = data;
|
||||
job_queue->size = job_queue->size + 1;
|
||||
|
||||
if (job_queue->size != job_queue->capacity) {
|
||||
@@ -74,7 +70,7 @@ int job_queue_pop(struct job_queue *job_queue, void **data) {
|
||||
}
|
||||
|
||||
job_queue->size = job_queue->size - 1;
|
||||
*data = (&job_queue->jobs)[job_queue->size];
|
||||
*data = job_queue->jobs[job_queue->size];
|
||||
|
||||
if (job_queue->size == 0) {
|
||||
pthread_mutex_unlock(&queue_destroy);
|
||||
|
||||
Reference in New Issue
Block a user