blob: b09e330c18c0bb4fce8a549f48dd055d1256d145 [file] [log] [blame]
/*
* Copyright (C) 2015 Filip Pizlo. All rights reserved.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY FILIP PIZLO ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL FILIP PIZLO OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "tsf_internal.h"
#include "gpc.h"
tsf_destructor_t *tsf_destructor_create(tsf_type_t *type) {
tsf_destructor_t *result;
gpc_proto_t *proto;
proto = tsf_gpc_code_gen_generate_destroyer(type);
if (proto == NULL) {
return NULL;
}
gpc_code_gen_debug("destroyer",proto);
result = malloc(sizeof(tsf_destructor_t));
if (result == NULL) {
tsf_set_errno("Could not malloc tsf_destructor_t");
gpc_proto_destroy(proto);
return NULL;
}
result->destructor = gpc_program_from_proto(proto);
gpc_proto_destroy(proto);
if (result->destructor == NULL) {
free(result);
return NULL;
}
return result;
}
void tsf_destructor_destroy(tsf_destructor_t *destructor) {
gpc_program_destroy(destructor->destructor);
free(destructor);
}
void tsf_destructor_destruct(tsf_destructor_t *destructor,
void *object) {
gpc_cell_t args[1];
args[0] = (gpc_cell_t)object;
gpc_program_run(destructor->destructor, NULL, args);
}