Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergey Sharybin <sergey.vfx@gmail.com>2014-02-26 03:58:14 +0400
committerCampbell Barton <ideasman42@gmail.com>2014-02-26 03:58:14 +0400
commit70924a7b2e018d18badfd731cac39702acfa5b08 (patch)
treeee99229f1af78dcb6f27236e806b78b86a6e5ce8
parent593d856217804bf5fcb2d33f8370bb8544c81316 (diff)
Fix T38548: Edit externally always uses first frame only
-rw-r--r--release/scripts/startup/bl_operators/image.py10
-rw-r--r--source/blender/makesrna/intern/rna_image_api.c15
2 files changed, 23 insertions, 2 deletions
diff --git a/release/scripts/startup/bl_operators/image.py b/release/scripts/startup/bl_operators/image.py
index 0d3d45d98fe..1653459bd71 100644
--- a/release/scripts/startup/bl_operators/image.py
+++ b/release/scripts/startup/bl_operators/image.py
@@ -90,8 +90,9 @@ class EditExternally(Operator):
def invoke(self, context, event):
import os
+ sd = context.space_data
try:
- image = context.space_data.image
+ image = sd.image
except AttributeError:
self.report({'ERROR'}, "Context incorrect, image not found")
return {'CANCELLED'}
@@ -100,7 +101,12 @@ class EditExternally(Operator):
self.report({'ERROR'}, "Image is packed, unpack before editing")
return {'CANCELLED'}
- filepath = bpy.path.abspath(image.filepath, library=image.library)
+ if sd.type == 'IMAGE_EDITOR':
+ filepath = image.filepath_from_user(sd.image_user)
+ else:
+ filepath = image.filepath
+
+ filepath = bpy.path.abspath(filepath, library=image.library)
self.filepath = os.path.normpath(filepath)
self.execute(context)
diff --git a/source/blender/makesrna/intern/rna_image_api.c b/source/blender/makesrna/intern/rna_image_api.c
index 8b6849a879a..57d74c91c86 100644
--- a/source/blender/makesrna/intern/rna_image_api.c
+++ b/source/blender/makesrna/intern/rna_image_api.c
@@ -37,6 +37,7 @@
#include "DNA_packedFile_types.h"
#include "BLI_utildefines.h"
+#include "BLI_path_util.h"
#include "BIF_gl.h"
@@ -277,6 +278,11 @@ static void rna_Image_gl_free(Image *image)
image->flag &= ~IMA_NOCOLLECT;
}
+static void rna_Image_filepath_from_user(Image *image, ImageUser *image_user, char *filepath)
+{
+ BKE_image_user_file_path(image_user, image, filepath);
+}
+
#else
void RNA_api_image(StructRNA *srna)
@@ -350,6 +356,15 @@ void RNA_api_image(StructRNA *srna)
func = RNA_def_function(srna, "gl_free", "rna_Image_gl_free");
RNA_def_function_ui_description(func, "Free the image from OpenGL graphics memory");
+ /* path to an frame specified by image user */
+ func = RNA_def_function(srna, "filepath_from_user", "rna_Image_filepath_from_user");
+ RNA_def_function_ui_description(func, "Return the absolute path to the filepath of an image frame specified by the image user");
+ RNA_def_pointer(func, "image_user", "ImageUser", "", "Image user of the image to get filepath for");
+ parm = RNA_def_string_file_path(func, "filepath", NULL, FILE_MAX, "File Path",
+ "The resulting filepath from the image and it's user");
+ RNA_def_property_flag(parm, PROP_THICK_WRAP); /* needed for string return value */
+ RNA_def_function_output(func, parm);
+
/* TODO, pack/unpack, maybe should be generic functions? */
}