Merge pull request #69447 from aaronfranke/3.x-gltf-organize-files

[3.x] GLTF: Organize structures and extensions into subfolders
This commit is contained in:
Rémi Verschelde 2022-12-01 18:14:04 +01:00
commit 01574a566f
No known key found for this signature in database
GPG key ID: C3336907360768E1
31 changed files with 45 additions and 23 deletions

10
modules/gltf/README.md Normal file
View file

@ -0,0 +1,10 @@
# Godot GLTF import and export module
In a nutshell, the GLTF module works like this:
* The [`structures/`](structures/) folder contains GLTF structures, the
small pieces that make up a GLTF file, represented as C++ classes.
* The [`extensions/`](extensions/) folder contains GLTF extensions, which
are optional features that build on top of the base GLTF spec.
* [`GLTFState`](gltf_state.h) holds collections of structures and extensions.
* [`GLTFDocument`](gltf_document.h) operates on GLTFState and its elements.

View file

@ -7,3 +7,5 @@ env_gltf = env_modules.Clone()
# Godot source files # Godot source files
env_gltf.add_source_files(env.modules_sources, "*.cpp") env_gltf.add_source_files(env.modules_sources, "*.cpp")
env_gltf.add_source_files(env.modules_sources, "structures/*.cpp")
SConscript("extensions/SCsub")

View file

@ -0,0 +1,9 @@
#!/usr/bin/env python
Import("env")
Import("env_modules")
env_gltf = env_modules.Clone()
# Godot source files
env_gltf.add_source_files(env.modules_sources, "*.cpp")

View file

@ -31,6 +31,7 @@
#ifndef GLTF_LIGHT_H #ifndef GLTF_LIGHT_H
#define GLTF_LIGHT_H #define GLTF_LIGHT_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
class GLTFLight : public Resource { class GLTFLight : public Resource {

View file

@ -31,6 +31,7 @@
#ifndef GLTF_SPEC_GLOSS_H #ifndef GLTF_SPEC_GLOSS_H
#define GLTF_SPEC_GLOSS_H #define GLTF_SPEC_GLOSS_H
#include "../gltf_defines.h"
#include "core/image.h" #include "core/image.h"
#include "core/resource.h" #include "core/resource.h"

View file

@ -30,7 +30,7 @@
#include "gltf_document.h" #include "gltf_document.h"
#include "gltf_spec_gloss.h" #include "extensions/gltf_spec_gloss.h"
#include "gltf_state.h" #include "gltf_state.h"
#include "core/bind/core_bind.h" // FIXME: Shouldn't use _Directory but DirAccess. #include "core/bind/core_bind.h" // FIXME: Shouldn't use _Directory but DirAccess.

View file

@ -32,6 +32,7 @@
#define GLTF_DOCUMENT_H #define GLTF_DOCUMENT_H
#include "gltf_defines.h" #include "gltf_defines.h"
#include "structures/gltf_animation.h"
#include "scene/3d/bone_attachment.h" #include "scene/3d/bone_attachment.h"
#include "scene/3d/camera.h" #include "scene/3d/camera.h"
@ -43,8 +44,6 @@
#include "scene/resources/material.h" #include "scene/resources/material.h"
#include "scene/resources/texture.h" #include "scene/resources/texture.h"
#include "gltf_animation.h"
#include "modules/modules_enabled.gen.h" // For csg, gridmap. #include "modules/modules_enabled.gen.h" // For csg, gridmap.
#ifdef MODULE_CSG_ENABLED #ifdef MODULE_CSG_ENABLED

View file

@ -31,18 +31,18 @@
#ifndef GLTF_STATE_H #ifndef GLTF_STATE_H
#define GLTF_STATE_H #define GLTF_STATE_H
#include "gltf_accessor.h" #include "extensions/gltf_light.h"
#include "gltf_animation.h"
#include "gltf_buffer_view.h"
#include "gltf_camera.h"
#include "gltf_light.h"
#include "gltf_mesh.h"
#include "gltf_node.h"
#include "gltf_skeleton.h"
#include "gltf_skin.h"
#include "gltf_template_convert.h" #include "gltf_template_convert.h"
#include "gltf_texture.h" #include "structures/gltf_accessor.h"
#include "gltf_texture_sampler.h" #include "structures/gltf_animation.h"
#include "structures/gltf_buffer_view.h"
#include "structures/gltf_camera.h"
#include "structures/gltf_mesh.h"
#include "structures/gltf_node.h"
#include "structures/gltf_skeleton.h"
#include "structures/gltf_skin.h"
#include "structures/gltf_texture.h"
#include "structures/gltf_texture_sampler.h"
class GLTFState : public Resource { class GLTFState : public Resource {
GDCLASS(GLTFState, Resource); GDCLASS(GLTFState, Resource);

View file

@ -32,7 +32,7 @@
#include "register_types.h" #include "register_types.h"
#include "gltf_spec_gloss.h" #include "extensions/gltf_spec_gloss.h"
#include "gltf_state.h" #include "gltf_state.h"
#ifdef TOOLS_ENABLED #ifdef TOOLS_ENABLED

View file

@ -31,8 +31,8 @@
#ifndef GLTF_ACCESSOR_H #ifndef GLTF_ACCESSOR_H
#define GLTF_ACCESSOR_H #define GLTF_ACCESSOR_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
struct GLTFAccessor : public Resource { struct GLTFAccessor : public Resource {
GDCLASS(GLTFAccessor, Resource); GDCLASS(GLTFAccessor, Resource);

View file

@ -31,8 +31,8 @@
#ifndef GLTF_BUFFER_VIEW_H #ifndef GLTF_BUFFER_VIEW_H
#define GLTF_BUFFER_VIEW_H #define GLTF_BUFFER_VIEW_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
class GLTFBufferView : public Resource { class GLTFBufferView : public Resource {
GDCLASS(GLTFBufferView, Resource); GDCLASS(GLTFBufferView, Resource);

View file

@ -31,8 +31,8 @@
#ifndef GLTF_NODE_H #ifndef GLTF_NODE_H
#define GLTF_NODE_H #define GLTF_NODE_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
class GLTFNode : public Resource { class GLTFNode : public Resource {
GDCLASS(GLTFNode, Resource); GDCLASS(GLTFNode, Resource);

View file

@ -30,7 +30,7 @@
#include "gltf_skeleton.h" #include "gltf_skeleton.h"
#include "gltf_template_convert.h" #include "../gltf_template_convert.h"
#include "scene/3d/bone_attachment.h" #include "scene/3d/bone_attachment.h"
void GLTFSkeleton::_bind_methods() { void GLTFSkeleton::_bind_methods() {

View file

@ -31,8 +31,8 @@
#ifndef GLTF_SKELETON_H #ifndef GLTF_SKELETON_H
#define GLTF_SKELETON_H #define GLTF_SKELETON_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
class GLTFSkeleton : public Resource { class GLTFSkeleton : public Resource {
GDCLASS(GLTFSkeleton, Resource); GDCLASS(GLTFSkeleton, Resource);

View file

@ -30,7 +30,7 @@
#include "gltf_skin.h" #include "gltf_skin.h"
#include "gltf_template_convert.h" #include "../gltf_template_convert.h"
#include "scene/resources/skin.h" #include "scene/resources/skin.h"
void GLTFSkin::_bind_methods() { void GLTFSkin::_bind_methods() {

View file

@ -31,8 +31,8 @@
#ifndef GLTF_SKIN_H #ifndef GLTF_SKIN_H
#define GLTF_SKIN_H #define GLTF_SKIN_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
class GLTFSkin : public Resource { class GLTFSkin : public Resource {
GDCLASS(GLTFSkin, Resource); GDCLASS(GLTFSkin, Resource);

View file

@ -31,8 +31,8 @@
#ifndef GLTF_TEXTURE_H #ifndef GLTF_TEXTURE_H
#define GLTF_TEXTURE_H #define GLTF_TEXTURE_H
#include "../gltf_defines.h"
#include "core/resource.h" #include "core/resource.h"
#include "gltf_defines.h"
class GLTFTexture : public Resource { class GLTFTexture : public Resource {
GDCLASS(GLTFTexture, Resource); GDCLASS(GLTFTexture, Resource);