[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [17586] branches/blender2.5/blender/source /blender/makesrna/intern:

Brecht Van Lommel brecht at blender.org
Wed Nov 26 23:24:27 CET 2008


Revision: 17586
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=17586
Author:   blendix
Date:     2008-11-26 23:24:26 +0100 (Wed, 26 Nov 2008)

Log Message:
-----------

RNA

* Made auto collection wrapping work for ** arrays.
  (Mesh.mats, still points to ID since there is no Material yet).
* Added sorting of RNA structs/properties before writing.

Modified Paths:
--------------
    branches/blender2.5/blender/source/blender/makesrna/intern/SConscript
    branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_access.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_define.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_mesh.c

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/SConscript
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/SConscript	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/SConscript	2008-11-26 22:24:26 UTC (rev 17586)
@@ -3,7 +3,7 @@
 import os
 
 Import ('env')
-cflags = '-Wall'
+cflags = ''
 defines = []
 root_build_dir=env['BF_BUILDDIR']
 

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c	2008-11-26 22:24:26 UTC (rev 17586)
@@ -44,6 +44,56 @@
 #endif
 #endif
 
+int cmp_struct(const void *a, const void *b)
+{
+	const StructRNA *structa= *(const StructRNA**)a;
+	const StructRNA *structb= *(const StructRNA**)b;
+
+	return strcmp(structa->identifier, structb->identifier);
+}
+
+int cmp_property(const void *a, const void *b)
+{
+	const PropertyRNA *propa= *(const PropertyRNA**)a;
+	const PropertyRNA *propb= *(const PropertyRNA**)b;
+
+	if(strcmp(propa->identifier, "rna_type") == 0) return -1;
+	else if(strcmp(propb->identifier, "rna_type") == 0) return 1;
+
+	if(strcmp(propa->identifier, "name") == 0) return -1;
+	else if(strcmp(propb->identifier, "name") == 0) return 1;
+
+	return strcmp(propa->name, propb->name);
+}
+
+void rna_sortlist(ListBase *listbase, int(*cmp)(const void*, const void*))
+{
+	Link *link;
+	void **array;
+	int a, size;
+	
+	if(listbase->first == listbase->last)
+		return;
+
+	for(size=0, link=listbase->first; link; link=link->next)
+		size++;
+
+	array= MEM_mallocN(sizeof(void*)*size, "rna_sortlist");
+	for(a=0, link=listbase->first; link; link=link->next, a++)
+		array[a]= link;
+
+	qsort(array, size, sizeof(void*), cmp);
+
+	listbase->first= listbase->last= NULL;
+	for(a=0; a<size; a++) {
+		link= array[a];
+		link->next= link->prev= NULL;
+		rna_addtail(listbase, link);
+	}
+
+	MEM_freeN(array);
+}
+
 /* Preprocessing */
 
 static void rna_print_c_string(FILE *f, const char *str)
@@ -499,6 +549,16 @@
 			rna_def_property_funcs(f, dp);
 }
 
+static void rna_sort(BlenderRNA *brna)
+{
+	StructRNA *srna;
+
+	rna_sortlist(&brna->structs, cmp_struct);
+
+	for(srna=brna->structs.first; srna; srna=srna->next)
+		rna_sortlist(&srna->properties, cmp_property);
+}
+
 static const char *rna_property_structname(PropertyType type)
 {
 	switch(type) {
@@ -830,6 +890,7 @@
 	fprintf(f, "\n");
 
 	rna_auto_functions(f);
+	rna_sort(brna);
 
 	for(srna=brna->structs.first; srna; srna=srna->next)
 		rna_generate_struct(brna, srna, f);

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_access.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_access.c	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_access.c	2008-11-26 22:24:26 UTC (rev 17586)
@@ -1106,6 +1106,14 @@
 	return internal->ptr;
 }
 
+void *rna_iterator_array_dereference_get(CollectionPropertyIterator *iter)
+{
+	ArrayIterator *internal= iter->internal;
+
+	/* for ** arrays */
+	return *(void**)(internal->ptr);
+}
+
 void rna_iterator_array_end(CollectionPropertyIterator *iter)
 {
 	MEM_freeN(iter->internal);

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_define.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_define.c	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_define.c	2008-11-26 22:24:26 UTC (rev 17586)
@@ -97,6 +97,7 @@
 	char *type;
 	char *name;
 	int arraylength;
+	int pointerlevel;
 } DNAStructMember;
 
 static int rna_member_cmp(const char *name, const char *oname)
@@ -125,7 +126,7 @@
 {
 	char *dnaname;
 	short *sp;
-	int a, structnr, totmember, cmp;
+	int a, b, structnr, totmember, cmp;
 
 	structnr= DNA_struct_find_nr(sdna, structname);
 	if(structnr == -1)
@@ -144,6 +145,11 @@
 			smember->type= sdna->types[sp[0]];
 			smember->name= dnaname;
 			smember->arraylength= DNA_elem_array_size(smember->name, strlen(smember->name));
+
+			smember->pointerlevel= 0;
+			for(b=0; dnaname[b] == '*'; b++)
+				smember->pointerlevel++;
+
 			return 1;
 		}
 		else if(cmp == 2) {
@@ -864,6 +870,7 @@
 	dp->dnaname= propname;
 	dp->dnatype= smember.type;
 	dp->dnaarraylength= smember.arraylength;
+	dp->dnapointerlevel= smember.pointerlevel;
 
 	return dp;
 }
@@ -1077,8 +1084,12 @@
 			dp->dnalengthname= lengthpropname;
 
 			cprop->next= (PropCollectionNextFunc)"rna_iterator_array_next";
-			cprop->get= (PropCollectionGetFunc)"rna_iterator_array_get";
 			cprop->end= (PropCollectionEndFunc)"rna_iterator_array_end";
+
+			if(dp->dnapointerlevel >= 2) 
+				cprop->get= (PropCollectionGetFunc)"rna_iterator_array_dereference_get";
+			else
+				cprop->get= (PropCollectionGetFunc)"rna_iterator_array_get";
 		}
 	}
 }

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h	2008-11-26 22:24:26 UTC (rev 17586)
@@ -46,6 +46,7 @@
 	const char *dnalengthname;
 	const char *dnatype;
 	int dnaarraylength;
+	int dnapointerlevel;
 
 	int booleanbit;
 } PropertyDefRNA;
@@ -136,6 +137,7 @@
 void rna_iterator_array_begin(struct CollectionPropertyIterator *iter, void *ptr, int itemsize, int length, IteratorSkipFunc skip);
 void rna_iterator_array_next(struct CollectionPropertyIterator *iter);
 void *rna_iterator_array_get(struct CollectionPropertyIterator *iter);
+void *rna_iterator_array_dereference_get(struct CollectionPropertyIterator *iter);
 void rna_iterator_array_end(struct CollectionPropertyIterator *iter);
 
 /* Duplicated code since we can't link in blenlib */

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_mesh.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_mesh.c	2008-11-26 17:47:42 UTC (rev 17585)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_mesh.c	2008-11-26 22:24:26 UTC (rev 17586)
@@ -721,7 +721,7 @@
 	RNA_def_property_float_funcs(prop, "rna_MCol_color4_get", "rna_MCol_color4_set", NULL);
 	RNA_def_property_ui_text(prop, "Color 4", "");
 
-	srna= RNA_def_struct(brna, "MColLayer", NULL, "Mesh Texture Face Layer");
+	srna= RNA_def_struct(brna, "MColLayer", NULL, "Mesh Vertex Color Layer");
 	RNA_def_struct_sdna(srna, "CustomDataLayer");
 
 	prop= RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
@@ -937,10 +937,10 @@
 	RNA_def_property_pointer_sdna(prop, NULL, "mr");
 	RNA_def_property_ui_text(prop, "Multires", "");
 
-	/*prop= RNA_def_property(srna, "materials", PROP_COLLECTION, PROP_NONE);
+	prop= RNA_def_property(srna, "materials", PROP_COLLECTION, PROP_NONE);
 	RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
-	RNA_def_property_struct_type(prop, "Material");
-	RNA_def_property_ui_text(prop, "Materials", "");*/
+	RNA_def_property_struct_type(prop, "ID");
+	RNA_def_property_ui_text(prop, "Materials", "");
 
 	/*prop= RNA_def_property(srna, "key", PROP_POINTER, PROP_NONE);
 	RNA_def_property_ui_text(prop, "Key", "");*/





More information about the Bf-blender-cvs mailing list