Expose an ImportOrder enum in ResourceImporter
This avoids using magic numbers in code.
This commit is contained in:
parent
515670351a
commit
7f83977f37
5 changed files with 28 additions and 3 deletions
|
@ -445,3 +445,8 @@ ResourceFormatImporter *ResourceFormatImporter::singleton = nullptr;
|
||||||
ResourceFormatImporter::ResourceFormatImporter() {
|
ResourceFormatImporter::ResourceFormatImporter() {
|
||||||
singleton = this;
|
singleton = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ResourceImporter::_bind_methods() {
|
||||||
|
BIND_ENUM_CONSTANT(IMPORT_ORDER_DEFAULT);
|
||||||
|
BIND_ENUM_CONSTANT(IMPORT_ORDER_SCENE);
|
||||||
|
}
|
||||||
|
|
|
@ -96,6 +96,9 @@ public:
|
||||||
class ResourceImporter : public RefCounted {
|
class ResourceImporter : public RefCounted {
|
||||||
GDCLASS(ResourceImporter, RefCounted);
|
GDCLASS(ResourceImporter, RefCounted);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
static void _bind_methods();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual String get_importer_name() const = 0;
|
virtual String get_importer_name() const = 0;
|
||||||
virtual String get_visible_name() const = 0;
|
virtual String get_visible_name() const = 0;
|
||||||
|
@ -103,7 +106,7 @@ public:
|
||||||
virtual String get_save_extension() const = 0;
|
virtual String get_save_extension() const = 0;
|
||||||
virtual String get_resource_type() const = 0;
|
virtual String get_resource_type() const = 0;
|
||||||
virtual float get_priority() const { return 1.0; }
|
virtual float get_priority() const { return 1.0; }
|
||||||
virtual int get_import_order() const { return 0; }
|
virtual int get_import_order() const { return IMPORT_ORDER_DEFAULT; }
|
||||||
virtual int get_format_version() const { return 0; }
|
virtual int get_format_version() const { return 0; }
|
||||||
|
|
||||||
struct ImportOption {
|
struct ImportOption {
|
||||||
|
@ -117,6 +120,11 @@ public:
|
||||||
ImportOption() {}
|
ImportOption() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum ImportOrder {
|
||||||
|
IMPORT_ORDER_DEFAULT = 0,
|
||||||
|
IMPORT_ORDER_SCENE = 100,
|
||||||
|
};
|
||||||
|
|
||||||
virtual bool has_advanced_options() const { return false; }
|
virtual bool has_advanced_options() const { return false; }
|
||||||
virtual void show_advanced_options(const String &p_path) {}
|
virtual void show_advanced_options(const String &p_path) {}
|
||||||
|
|
||||||
|
@ -137,4 +145,6 @@ public:
|
||||||
virtual String get_import_settings_string() const { return String(); }
|
virtual String get_import_settings_string() const { return String(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
VARIANT_ENUM_CAST(ResourceImporter::ImportOrder);
|
||||||
|
|
||||||
#endif // RESOURCE_IMPORTER_H
|
#endif // RESOURCE_IMPORTER_H
|
||||||
|
|
|
@ -126,7 +126,7 @@
|
||||||
<return type="int">
|
<return type="int">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
Gets the order of this importer to be run when importing resources. Higher values will be called later. Use this to ensure the importer runs after the dependencies are already imported.
|
Gets the order of this importer to be run when importing resources. Importers with [i]lower[/i] import orders will be called first, and higher values will be called later. Use this to ensure the importer runs after the dependencies are already imported. The default import order is [code]0[/code] unless overridden by a specific importer. See [enum ResourceImporter.ImportOrder] for some predefined values.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="_get_importer_name" qualifiers="virtual">
|
<method name="_get_importer_name" qualifiers="virtual">
|
||||||
|
|
|
@ -1,13 +1,22 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<class name="ResourceImporter" inherits="RefCounted" version="4.0">
|
<class name="ResourceImporter" inherits="RefCounted" version="4.0">
|
||||||
<brief_description>
|
<brief_description>
|
||||||
|
Base class for the implementation of core resource importers.
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
|
This is the base class for the resource importers implemented in core. To implement your own resource importers using editor plugins, see [EditorImportPlugin].
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
|
<link title="Import plugins">https://docs.godotengine.org/en/latest/tutorials/plugins/editor/import_plugins.html</link>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
<methods>
|
<methods>
|
||||||
</methods>
|
</methods>
|
||||||
<constants>
|
<constants>
|
||||||
|
<constant name="IMPORT_ORDER_DEFAULT" value="0" enum="ImportOrder">
|
||||||
|
The default import order.
|
||||||
|
</constant>
|
||||||
|
<constant name="IMPORT_ORDER_SCENE" value="100" enum="ImportOrder">
|
||||||
|
The import order for scenes, which ensures scenes are imported [i]after[/i] all other core resources such as textures. Custom importers should generally have an import order lower than [code]100[/code] to avoid issues when importing scenes that rely on custom resources.
|
||||||
|
</constant>
|
||||||
</constants>
|
</constants>
|
||||||
</class>
|
</class>
|
||||||
|
|
|
@ -155,7 +155,8 @@ public:
|
||||||
|
|
||||||
virtual void get_import_options(List<ImportOption> *r_options, int p_preset = 0) const override;
|
virtual void get_import_options(List<ImportOption> *r_options, int p_preset = 0) const override;
|
||||||
virtual bool get_option_visibility(const String &p_option, const Map<StringName, Variant> &p_options) const override;
|
virtual bool get_option_visibility(const String &p_option, const Map<StringName, Variant> &p_options) const override;
|
||||||
virtual int get_import_order() const override { return 100; } //after everything
|
// Import scenes *after* everything else (such as textures).
|
||||||
|
virtual int get_import_order() const override { return ResourceImporter::IMPORT_ORDER_SCENE; }
|
||||||
|
|
||||||
Node *_pre_fix_node(Node *p_node, Node *p_root, Map<Ref<EditorSceneImporterMesh>, List<Ref<Shape3D>>> &collision_map);
|
Node *_pre_fix_node(Node *p_node, Node *p_root, Map<Ref<EditorSceneImporterMesh>, List<Ref<Shape3D>>> &collision_map);
|
||||||
Node *_post_fix_node(Node *p_node, Node *p_root, Map<Ref<EditorSceneImporterMesh>, List<Ref<Shape3D>>> &collision_map, Set<Ref<EditorSceneImporterMesh>> &r_scanned_meshes, const Dictionary &p_node_data, const Dictionary &p_material_data, const Dictionary &p_animation_data, float p_animation_fps);
|
Node *_post_fix_node(Node *p_node, Node *p_root, Map<Ref<EditorSceneImporterMesh>, List<Ref<Shape3D>>> &collision_map, Set<Ref<EditorSceneImporterMesh>> &r_scanned_meshes, const Dictionary &p_node_data, const Dictionary &p_material_data, const Dictionary &p_animation_data, float p_animation_fps);
|
||||||
|
|
Loading…
Reference in a new issue