Updated cgltf.
This commit is contained in:
parent
cd3a1ea7f8
commit
35b0fdd60b
37
3rdparty/cgltf/cgltf.h
vendored
37
3rdparty/cgltf/cgltf.h
vendored
@ -65,7 +65,8 @@
|
|||||||
*
|
*
|
||||||
* `cgltf_num_components` is a tiny utility that tells you the dimensionality of
|
* `cgltf_num_components` is a tiny utility that tells you the dimensionality of
|
||||||
* a certain accessor type. This can be used before `cgltf_accessor_unpack_floats` to help allocate
|
* a certain accessor type. This can be used before `cgltf_accessor_unpack_floats` to help allocate
|
||||||
* the necessary amount of memory.
|
* the necessary amount of memory. `cgltf_component_size` and `cgltf_calc_size` exist for
|
||||||
|
* similar purposes.
|
||||||
*
|
*
|
||||||
* `cgltf_accessor_read_float` reads a certain element from a non-sparse accessor and converts it to
|
* `cgltf_accessor_read_float` reads a certain element from a non-sparse accessor and converts it to
|
||||||
* floating point, assuming that `cgltf_load_buffers` has already been called. The passed-in element
|
* floating point, assuming that `cgltf_load_buffers` has already been called. The passed-in element
|
||||||
@ -837,6 +838,8 @@ cgltf_bool cgltf_accessor_read_uint(const cgltf_accessor* accessor, cgltf_size i
|
|||||||
cgltf_size cgltf_accessor_read_index(const cgltf_accessor* accessor, cgltf_size index);
|
cgltf_size cgltf_accessor_read_index(const cgltf_accessor* accessor, cgltf_size index);
|
||||||
|
|
||||||
cgltf_size cgltf_num_components(cgltf_type type);
|
cgltf_size cgltf_num_components(cgltf_type type);
|
||||||
|
cgltf_size cgltf_component_size(cgltf_component_type component_type);
|
||||||
|
cgltf_size cgltf_calc_size(cgltf_type type, cgltf_component_type component_type);
|
||||||
|
|
||||||
cgltf_size cgltf_accessor_unpack_floats(const cgltf_accessor* accessor, cgltf_float* out, cgltf_size float_count);
|
cgltf_size cgltf_accessor_unpack_floats(const cgltf_accessor* accessor, cgltf_float* out, cgltf_size float_count);
|
||||||
|
|
||||||
@ -904,15 +907,15 @@ enum jsmnerr {
|
|||||||
};
|
};
|
||||||
typedef struct {
|
typedef struct {
|
||||||
jsmntype_t type;
|
jsmntype_t type;
|
||||||
int start;
|
ptrdiff_t start;
|
||||||
int end;
|
ptrdiff_t end;
|
||||||
int size;
|
int size;
|
||||||
#ifdef JSMN_PARENT_LINKS
|
#ifdef JSMN_PARENT_LINKS
|
||||||
int parent;
|
int parent;
|
||||||
#endif
|
#endif
|
||||||
} jsmntok_t;
|
} jsmntok_t;
|
||||||
typedef struct {
|
typedef struct {
|
||||||
unsigned int pos; /* offset in the JSON string */
|
size_t pos; /* offset in the JSON string */
|
||||||
unsigned int toknext; /* next token to allocate */
|
unsigned int toknext; /* next token to allocate */
|
||||||
int toksuper; /* superior token node, e.g parent object or array */
|
int toksuper; /* superior token node, e.g parent object or array */
|
||||||
} jsmn_parser;
|
} jsmn_parser;
|
||||||
@ -1488,8 +1491,6 @@ cgltf_result cgltf_load_buffers(const cgltf_options* options, cgltf_data* data,
|
|||||||
return cgltf_result_success;
|
return cgltf_result_success;
|
||||||
}
|
}
|
||||||
|
|
||||||
static cgltf_size cgltf_calc_size(cgltf_type type, cgltf_component_type component_type);
|
|
||||||
|
|
||||||
static cgltf_size cgltf_calc_index_bound(cgltf_buffer_view* buffer_view, cgltf_size offset, cgltf_component_type component_type, cgltf_size count)
|
static cgltf_size cgltf_calc_index_bound(cgltf_buffer_view* buffer_view, cgltf_size offset, cgltf_component_type component_type, cgltf_size count)
|
||||||
{
|
{
|
||||||
char* data = (char*)buffer_view->buffer->data + offset + buffer_view->offset;
|
char* data = (char*)buffer_view->buffer->data + offset + buffer_view->offset;
|
||||||
@ -2253,8 +2254,6 @@ static cgltf_float cgltf_component_read_float(const void* in, cgltf_component_ty
|
|||||||
return (cgltf_float)cgltf_component_read_integer(in, component_type);
|
return (cgltf_float)cgltf_component_read_integer(in, component_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
static cgltf_size cgltf_component_size(cgltf_component_type component_type);
|
|
||||||
|
|
||||||
static cgltf_bool cgltf_element_read_float(const uint8_t* element, cgltf_type type, cgltf_component_type component_type, cgltf_bool normalized, cgltf_float* out, cgltf_size element_size)
|
static cgltf_bool cgltf_element_read_float(const uint8_t* element, cgltf_type type, cgltf_component_type component_type, cgltf_bool normalized, cgltf_float* out, cgltf_size element_size)
|
||||||
{
|
{
|
||||||
cgltf_size num_components = cgltf_num_components(type);
|
cgltf_size num_components = cgltf_num_components(type);
|
||||||
@ -2505,7 +2504,7 @@ static int cgltf_json_strcmp(jsmntok_t const* tok, const uint8_t* json_chunk, co
|
|||||||
{
|
{
|
||||||
CGLTF_CHECK_TOKTYPE(*tok, JSMN_STRING);
|
CGLTF_CHECK_TOKTYPE(*tok, JSMN_STRING);
|
||||||
size_t const str_len = strlen(str);
|
size_t const str_len = strlen(str);
|
||||||
size_t const name_length = tok->end - tok->start;
|
size_t const name_length = (size_t)(tok->end - tok->start);
|
||||||
return (str_len == name_length) ? strncmp((const char*)json_chunk + tok->start, str, str_len) : 128;
|
return (str_len == name_length) ? strncmp((const char*)json_chunk + tok->start, str, str_len) : 128;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2513,7 +2512,7 @@ static int cgltf_json_to_int(jsmntok_t const* tok, const uint8_t* json_chunk)
|
|||||||
{
|
{
|
||||||
CGLTF_CHECK_TOKTYPE(*tok, JSMN_PRIMITIVE);
|
CGLTF_CHECK_TOKTYPE(*tok, JSMN_PRIMITIVE);
|
||||||
char tmp[128];
|
char tmp[128];
|
||||||
int size = (cgltf_size)(tok->end - tok->start) < sizeof(tmp) ? tok->end - tok->start : (int)(sizeof(tmp) - 1);
|
int size = (size_t)(tok->end - tok->start) < sizeof(tmp) ? (int)(tok->end - tok->start) : (int)(sizeof(tmp) - 1);
|
||||||
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
||||||
tmp[size] = 0;
|
tmp[size] = 0;
|
||||||
return CGLTF_ATOI(tmp);
|
return CGLTF_ATOI(tmp);
|
||||||
@ -2523,7 +2522,7 @@ static cgltf_size cgltf_json_to_size(jsmntok_t const* tok, const uint8_t* json_c
|
|||||||
{
|
{
|
||||||
CGLTF_CHECK_TOKTYPE_RETTYPE(*tok, JSMN_PRIMITIVE, cgltf_size);
|
CGLTF_CHECK_TOKTYPE_RETTYPE(*tok, JSMN_PRIMITIVE, cgltf_size);
|
||||||
char tmp[128];
|
char tmp[128];
|
||||||
int size = (cgltf_size)(tok->end - tok->start) < sizeof(tmp) ? tok->end - tok->start : (int)(sizeof(tmp) - 1);
|
int size = (size_t)(tok->end - tok->start) < sizeof(tmp) ? (int)(tok->end - tok->start) : (int)(sizeof(tmp) - 1);
|
||||||
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
||||||
tmp[size] = 0;
|
tmp[size] = 0;
|
||||||
return (cgltf_size)CGLTF_ATOLL(tmp);
|
return (cgltf_size)CGLTF_ATOLL(tmp);
|
||||||
@ -2533,7 +2532,7 @@ static cgltf_float cgltf_json_to_float(jsmntok_t const* tok, const uint8_t* json
|
|||||||
{
|
{
|
||||||
CGLTF_CHECK_TOKTYPE(*tok, JSMN_PRIMITIVE);
|
CGLTF_CHECK_TOKTYPE(*tok, JSMN_PRIMITIVE);
|
||||||
char tmp[128];
|
char tmp[128];
|
||||||
int size = (cgltf_size)(tok->end - tok->start) < sizeof(tmp) ? tok->end - tok->start : (int)(sizeof(tmp) - 1);
|
int size = (size_t)(tok->end - tok->start) < sizeof(tmp) ? (int)(tok->end - tok->start) : (int)(sizeof(tmp) - 1);
|
||||||
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
strncpy(tmp, (const char*)json_chunk + tok->start, size);
|
||||||
tmp[size] = 0;
|
tmp[size] = 0;
|
||||||
return (cgltf_float)CGLTF_ATOF(tmp);
|
return (cgltf_float)CGLTF_ATOF(tmp);
|
||||||
@ -2541,7 +2540,7 @@ static cgltf_float cgltf_json_to_float(jsmntok_t const* tok, const uint8_t* json
|
|||||||
|
|
||||||
static cgltf_bool cgltf_json_to_bool(jsmntok_t const* tok, const uint8_t* json_chunk)
|
static cgltf_bool cgltf_json_to_bool(jsmntok_t const* tok, const uint8_t* json_chunk)
|
||||||
{
|
{
|
||||||
int size = tok->end - tok->start;
|
int size = (int)(tok->end - tok->start);
|
||||||
return size == 4 && memcmp(json_chunk + tok->start, "true", 4) == 0;
|
return size == 4 && memcmp(json_chunk + tok->start, "true", 4) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2607,7 +2606,7 @@ static int cgltf_parse_json_string(cgltf_options* options, jsmntok_t const* toke
|
|||||||
{
|
{
|
||||||
return CGLTF_ERROR_JSON;
|
return CGLTF_ERROR_JSON;
|
||||||
}
|
}
|
||||||
int size = tokens[i].end - tokens[i].start;
|
int size = (int)(tokens[i].end - tokens[i].start);
|
||||||
char* result = (char*)options->memory.alloc_func(options->memory.user_data, size + 1);
|
char* result = (char*)options->memory.alloc_func(options->memory.user_data, size + 1);
|
||||||
if (!result)
|
if (!result)
|
||||||
{
|
{
|
||||||
@ -5965,7 +5964,7 @@ cgltf_size cgltf_num_components(cgltf_type type) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static cgltf_size cgltf_component_size(cgltf_component_type component_type) {
|
cgltf_size cgltf_component_size(cgltf_component_type component_type) {
|
||||||
switch (component_type)
|
switch (component_type)
|
||||||
{
|
{
|
||||||
case cgltf_component_type_r_8:
|
case cgltf_component_type_r_8:
|
||||||
@ -5983,7 +5982,7 @@ static cgltf_size cgltf_component_size(cgltf_component_type component_type) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static cgltf_size cgltf_calc_size(cgltf_type type, cgltf_component_type component_type)
|
cgltf_size cgltf_calc_size(cgltf_type type, cgltf_component_type component_type)
|
||||||
{
|
{
|
||||||
cgltf_size component_size = cgltf_component_size(component_type);
|
cgltf_size component_size = cgltf_component_size(component_type);
|
||||||
if (type == cgltf_type_mat2 && component_size == 1)
|
if (type == cgltf_type_mat2 && component_size == 1)
|
||||||
@ -6501,7 +6500,7 @@ static jsmntok_t *jsmn_alloc_token(jsmn_parser *parser,
|
|||||||
* Fills token type and boundaries.
|
* Fills token type and boundaries.
|
||||||
*/
|
*/
|
||||||
static void jsmn_fill_token(jsmntok_t *token, jsmntype_t type,
|
static void jsmn_fill_token(jsmntok_t *token, jsmntype_t type,
|
||||||
int start, int end) {
|
ptrdiff_t start, ptrdiff_t end) {
|
||||||
token->type = type;
|
token->type = type;
|
||||||
token->start = start;
|
token->start = start;
|
||||||
token->end = end;
|
token->end = end;
|
||||||
@ -6514,7 +6513,7 @@ static void jsmn_fill_token(jsmntok_t *token, jsmntype_t type,
|
|||||||
static int jsmn_parse_primitive(jsmn_parser *parser, const char *js,
|
static int jsmn_parse_primitive(jsmn_parser *parser, const char *js,
|
||||||
size_t len, jsmntok_t *tokens, size_t num_tokens) {
|
size_t len, jsmntok_t *tokens, size_t num_tokens) {
|
||||||
jsmntok_t *token;
|
jsmntok_t *token;
|
||||||
int start;
|
ptrdiff_t start;
|
||||||
|
|
||||||
start = parser->pos;
|
start = parser->pos;
|
||||||
|
|
||||||
@ -6564,7 +6563,7 @@ static int jsmn_parse_string(jsmn_parser *parser, const char *js,
|
|||||||
size_t len, jsmntok_t *tokens, size_t num_tokens) {
|
size_t len, jsmntok_t *tokens, size_t num_tokens) {
|
||||||
jsmntok_t *token;
|
jsmntok_t *token;
|
||||||
|
|
||||||
int start = parser->pos;
|
ptrdiff_t start = parser->pos;
|
||||||
|
|
||||||
parser->pos++;
|
parser->pos++;
|
||||||
|
|
||||||
|
1
3rdparty/cgltf/cgltf_write.h
vendored
1
3rdparty/cgltf/cgltf_write.h
vendored
@ -1123,6 +1123,7 @@ static void cgltf_write_light(cgltf_write_context* context, const cgltf_light* l
|
|||||||
cgltf_write_floatprop(context, "outerConeAngle", light->spot_outer_cone_angle, 3.14159265358979323846f/4.0f);
|
cgltf_write_floatprop(context, "outerConeAngle", light->spot_outer_cone_angle, 3.14159265358979323846f/4.0f);
|
||||||
cgltf_write_line(context, "}");
|
cgltf_write_line(context, "}");
|
||||||
}
|
}
|
||||||
|
cgltf_write_extras( context, &light->extras );
|
||||||
cgltf_write_line(context, "}");
|
cgltf_write_line(context, "}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user