mie: refactor ir api into a separate sub-directory
This commit is contained in:
52
mie/ir/data.c
Normal file
52
mie/ir/data.c
Normal file
@@ -0,0 +1,52 @@
|
||||
#include <blue/object/string.h>
|
||||
#include <mie/ir/ctx.h>
|
||||
#include <mie/ir/data.h>
|
||||
#include <mie/ir/type.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
struct mie_data *mie_data_create_extern_global(
|
||||
struct mie_type *type, const char *ident)
|
||||
{
|
||||
struct mie_data *data = malloc(sizeof *data);
|
||||
if (!data) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memset(data, 0x0, sizeof *data);
|
||||
|
||||
mie_value_init(&data->d_base, MIE_VALUE_DATA);
|
||||
|
||||
data->d_type = MIE_DATA_EXTERN_GLOBAL;
|
||||
data->d_extern_global.g_type = type;
|
||||
data->d_base.v_name.n_str = b_strdup(ident);
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
struct mie_data *mie_data_create_const(struct mie_const *value)
|
||||
{
|
||||
struct mie_data *data = malloc(sizeof *data);
|
||||
if (!data) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
memset(data, 0x0, sizeof *data);
|
||||
|
||||
mie_value_init(&data->d_base, MIE_VALUE_DATA);
|
||||
|
||||
data->d_type = MIE_DATA_CONST;
|
||||
data->d_const.c_value = value;
|
||||
|
||||
return data;
|
||||
}
|
||||
|
||||
static struct mie_type *get_type(struct mie_value *v, struct mie_ctx *ctx)
|
||||
{
|
||||
return mie_ctx_get_type(ctx, MIE_TYPE_PTR);
|
||||
}
|
||||
|
||||
const struct mie_value_type data_value_type = {
|
||||
.t_id = MIE_VALUE_DATA,
|
||||
.t_get_type = get_type,
|
||||
};
|
||||
Reference in New Issue
Block a user