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:
authorTamito Kajiyama <rd6t-kjym@asahi-net.or.jp>2013-03-20 03:54:14 +0400
committerTamito Kajiyama <rd6t-kjym@asahi-net.or.jp>2013-03-20 03:54:14 +0400
commite1ce7f3f85377b922df2c50d12bbc89d0b7b4f74 (patch)
tree34b9867fd1137f2daacba676d07af56b699b2351 /source/blender/blenkernel/intern/linestyle.c
parentdbd0c3711971faa89c01bb5504bc0d76ccdeec1b (diff)
Code clean-up suggested by Sergey Sharybin through a code review of the branch.
* Removed the checks of NULL pointers after malloc/calloc. * Replaced repeated cast operations with a temporary variable initialized with one cast operation. * Removed an unused switch block (meant to be a place to put per-modifier resource management code).
Diffstat (limited to 'source/blender/blenkernel/intern/linestyle.c')
-rw-r--r--source/blender/blenkernel/intern/linestyle.c440
1 files changed, 244 insertions, 196 deletions
diff --git a/source/blender/blenkernel/intern/linestyle.c b/source/blender/blenkernel/intern/linestyle.c
index ca3a910f403..67f1d02024a 100644
--- a/source/blender/blenkernel/intern/linestyle.c
+++ b/source/blender/blenkernel/intern/linestyle.c
@@ -176,12 +176,10 @@ static LineStyleModifier *new_modifier(int type, size_t size)
LineStyleModifier *m;
m = (LineStyleModifier *)MEM_callocN(size, "line style modifier");
- if (m) {
- m->type = type;
- strcpy(m->name, modifier_name[type]);
- m->influence = 1.0f;
- m->flags = LS_MODIFIER_ENABLED | LS_MODIFIER_EXPANDED;
- }
+ m->type = type;
+ strcpy(m->name, modifier_name[type]);
+ m->influence = 1.0f;
+ m->flags = LS_MODIFIER_ENABLED | LS_MODIFIER_EXPANDED;
return m;
}
@@ -221,8 +219,6 @@ LineStyleModifier *FRS_add_linestyle_color_modifier(FreestyleLineStyle *linestyl
LineStyleModifier *m;
m = alloc_color_modifier(type);
- if (!m)
- return NULL;
m->blend = MA_RAMP_BLEND;
switch (type) {
@@ -257,8 +253,6 @@ LineStyleModifier *FRS_copy_linestyle_color_modifier(FreestyleLineStyle *linesty
LineStyleModifier *new_m;
new_m = alloc_color_modifier(m->type);
- if (!new_m)
- return NULL;
new_m->influence = m->influence;
new_m->flags = m->flags;
new_m->blend = m->blend;
@@ -267,33 +261,37 @@ LineStyleModifier *FRS_copy_linestyle_color_modifier(FreestyleLineStyle *linesty
case LS_MODIFIER_ALONG_STROKE:
{
LineStyleColorModifier_AlongStroke *p = (LineStyleColorModifier_AlongStroke *)m;
- ((LineStyleColorModifier_AlongStroke *)new_m)->color_ramp = MEM_dupallocN(p->color_ramp);
+ LineStyleColorModifier_AlongStroke *q = (LineStyleColorModifier_AlongStroke *)new_m;
+ q->color_ramp = MEM_dupallocN(p->color_ramp);
}
break;
case LS_MODIFIER_DISTANCE_FROM_CAMERA:
{
LineStyleColorModifier_DistanceFromCamera *p = (LineStyleColorModifier_DistanceFromCamera *)m;
- ((LineStyleColorModifier_DistanceFromCamera *)new_m)->color_ramp = MEM_dupallocN(p->color_ramp);
- ((LineStyleColorModifier_DistanceFromCamera *)new_m)->range_min = p->range_min;
- ((LineStyleColorModifier_DistanceFromCamera *)new_m)->range_max = p->range_max;
+ LineStyleColorModifier_DistanceFromCamera *q = (LineStyleColorModifier_DistanceFromCamera *)new_m;
+ q->color_ramp = MEM_dupallocN(p->color_ramp);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
}
break;
case LS_MODIFIER_DISTANCE_FROM_OBJECT:
{
LineStyleColorModifier_DistanceFromObject *p = (LineStyleColorModifier_DistanceFromObject *)m;
+ LineStyleColorModifier_DistanceFromObject *q = (LineStyleColorModifier_DistanceFromObject *)new_m;
if (p->target)
p->target->id.us++;
- ((LineStyleColorModifier_DistanceFromObject *)new_m)->target = p->target;
- ((LineStyleColorModifier_DistanceFromObject *)new_m)->color_ramp = MEM_dupallocN(p->color_ramp);
- ((LineStyleColorModifier_DistanceFromObject *)new_m)->range_min = p->range_min;
- ((LineStyleColorModifier_DistanceFromObject *)new_m)->range_max = p->range_max;
+ q->target = p->target;
+ q->color_ramp = MEM_dupallocN(p->color_ramp);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
}
break;
case LS_MODIFIER_MATERIAL:
{
LineStyleColorModifier_Material *p = (LineStyleColorModifier_Material *)m;
- ((LineStyleColorModifier_Material *)new_m)->color_ramp = MEM_dupallocN(p->color_ramp);
- ((LineStyleColorModifier_Material *)new_m)->mat_attr = p->mat_attr;
+ LineStyleColorModifier_Material *q = (LineStyleColorModifier_Material *)new_m;
+ q->color_ramp = MEM_dupallocN(p->color_ramp);
+ q->mat_attr = p->mat_attr;
}
break;
default:
@@ -351,28 +349,38 @@ LineStyleModifier *FRS_add_linestyle_alpha_modifier(FreestyleLineStyle *linestyl
LineStyleModifier *m;
m = alloc_alpha_modifier(type);
- if (!m)
- return NULL;
m->blend = LS_VALUE_BLEND;
switch (type) {
case LS_MODIFIER_ALONG_STROKE:
- ((LineStyleAlphaModifier_AlongStroke *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ {
+ LineStyleAlphaModifier_AlongStroke *p = (LineStyleAlphaModifier_AlongStroke *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ }
break;
case LS_MODIFIER_DISTANCE_FROM_CAMERA:
- ((LineStyleAlphaModifier_DistanceFromCamera *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleAlphaModifier_DistanceFromCamera *)m)->range_min = 0.0f;
- ((LineStyleAlphaModifier_DistanceFromCamera *)m)->range_max = 10000.0f;
+ {
+ LineStyleAlphaModifier_DistanceFromCamera *p = (LineStyleAlphaModifier_DistanceFromCamera *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->range_min = 0.0f;
+ p->range_max = 10000.0f;
+ }
break;
case LS_MODIFIER_DISTANCE_FROM_OBJECT:
- ((LineStyleAlphaModifier_DistanceFromObject *)m)->target = NULL;
- ((LineStyleAlphaModifier_DistanceFromObject *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleAlphaModifier_DistanceFromObject *)m)->range_min = 0.0f;
- ((LineStyleAlphaModifier_DistanceFromObject *)m)->range_max = 10000.0f;
+ {
+ LineStyleAlphaModifier_DistanceFromObject *p = (LineStyleAlphaModifier_DistanceFromObject *)m;
+ p->target = NULL;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->range_min = 0.0f;
+ p->range_max = 10000.0f;
+ }
break;
case LS_MODIFIER_MATERIAL:
- ((LineStyleAlphaModifier_Material *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleAlphaModifier_Material *)m)->mat_attr = LS_MODIFIER_MATERIAL_DIFF;
+ {
+ LineStyleAlphaModifier_Material *p = (LineStyleAlphaModifier_Material *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->mat_attr = LS_MODIFIER_MATERIAL_DIFF;
+ }
break;
default:
return NULL; /* unknown modifier type */
@@ -387,8 +395,6 @@ LineStyleModifier *FRS_copy_linestyle_alpha_modifier(FreestyleLineStyle *linesty
LineStyleModifier *new_m;
new_m = alloc_alpha_modifier(m->type);
- if (!new_m)
- return NULL;
new_m->influence = m->influence;
new_m->flags = m->flags;
new_m->blend = m->blend;
@@ -397,33 +403,37 @@ LineStyleModifier *FRS_copy_linestyle_alpha_modifier(FreestyleLineStyle *linesty
case LS_MODIFIER_ALONG_STROKE:
{
LineStyleAlphaModifier_AlongStroke *p = (LineStyleAlphaModifier_AlongStroke *)m;
- ((LineStyleAlphaModifier_AlongStroke *)new_m)->curve = curvemapping_copy(p->curve);
+ LineStyleAlphaModifier_AlongStroke *q = (LineStyleAlphaModifier_AlongStroke *)new_m;
+ q->curve = curvemapping_copy(p->curve);
}
break;
case LS_MODIFIER_DISTANCE_FROM_CAMERA:
{
LineStyleAlphaModifier_DistanceFromCamera *p = (LineStyleAlphaModifier_DistanceFromCamera *)m;
- ((LineStyleAlphaModifier_DistanceFromCamera *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleAlphaModifier_DistanceFromCamera *)new_m)->range_min = p->range_min;
- ((LineStyleAlphaModifier_DistanceFromCamera *)new_m)->range_max = p->range_max;
+ LineStyleAlphaModifier_DistanceFromCamera *q = (LineStyleAlphaModifier_DistanceFromCamera *)new_m;
+ q->curve = curvemapping_copy(p->curve);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
}
break;
case LS_MODIFIER_DISTANCE_FROM_OBJECT:
{
LineStyleAlphaModifier_DistanceFromObject *p = (LineStyleAlphaModifier_DistanceFromObject *)m;
+ LineStyleAlphaModifier_DistanceFromObject *q = (LineStyleAlphaModifier_DistanceFromObject *)new_m;
if (p->target)
p->target->id.us++;
- ((LineStyleAlphaModifier_DistanceFromObject *)new_m)->target = p->target;
- ((LineStyleAlphaModifier_DistanceFromObject *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleAlphaModifier_DistanceFromObject *)new_m)->range_min = p->range_min;
- ((LineStyleAlphaModifier_DistanceFromObject *)new_m)->range_max = p->range_max;
+ q->target = p->target;
+ q->curve = curvemapping_copy(p->curve);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
}
break;
case LS_MODIFIER_MATERIAL:
{
LineStyleAlphaModifier_Material *p = (LineStyleAlphaModifier_Material *)m;
- ((LineStyleAlphaModifier_Material *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleAlphaModifier_Material *)new_m)->mat_attr = p->mat_attr;
+ LineStyleAlphaModifier_Material *q = (LineStyleAlphaModifier_Material *)new_m;
+ q->curve = curvemapping_copy(p->curve);
+ q->mat_attr = p->mat_attr;
}
break;
default:
@@ -485,41 +495,54 @@ LineStyleModifier *FRS_add_linestyle_thickness_modifier(FreestyleLineStyle *line
LineStyleModifier *m;
m = alloc_thickness_modifier(type);
- if (!m)
- return NULL;
m->blend = LS_VALUE_BLEND;
switch (type) {
case LS_MODIFIER_ALONG_STROKE:
- ((LineStyleThicknessModifier_AlongStroke *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleThicknessModifier_AlongStroke *)m)->value_min = 0.0f;
- ((LineStyleThicknessModifier_AlongStroke *)m)->value_max = 1.0f;
+ {
+ LineStyleThicknessModifier_AlongStroke *p = (LineStyleThicknessModifier_AlongStroke *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->value_min = 0.0f;
+ p->value_max = 1.0f;
+ }
break;
case LS_MODIFIER_DISTANCE_FROM_CAMERA:
- ((LineStyleThicknessModifier_DistanceFromCamera *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleThicknessModifier_DistanceFromCamera *)m)->range_min = 0.0f;
- ((LineStyleThicknessModifier_DistanceFromCamera *)m)->range_max = 1000.0f;
- ((LineStyleThicknessModifier_DistanceFromCamera *)m)->value_min = 0.0f;
- ((LineStyleThicknessModifier_DistanceFromCamera *)m)->value_max = 1.0f;
+ {
+ LineStyleThicknessModifier_DistanceFromCamera *p = (LineStyleThicknessModifier_DistanceFromCamera *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->range_min = 0.0f;
+ p->range_max = 1000.0f;
+ p->value_min = 0.0f;
+ p->value_max = 1.0f;
+ }
break;
case LS_MODIFIER_DISTANCE_FROM_OBJECT:
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->target = NULL;
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->range_min = 0.0f;
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->range_max = 1000.0f;
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->value_min = 0.0f;
- ((LineStyleThicknessModifier_DistanceFromObject *)m)->value_max = 1.0f;
+ {
+ LineStyleThicknessModifier_DistanceFromObject *p = (LineStyleThicknessModifier_DistanceFromObject *)m;
+ p->target = NULL;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->range_min = 0.0f;
+ p->range_max = 1000.0f;
+ p->value_min = 0.0f;
+ p->value_max = 1.0f;
+ }
break;
case LS_MODIFIER_MATERIAL:
- ((LineStyleThicknessModifier_Material *)m)->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
- ((LineStyleThicknessModifier_Material *)m)->mat_attr = LS_MODIFIER_MATERIAL_DIFF;
- ((LineStyleThicknessModifier_Material *)m)->value_min = 0.0f;
- ((LineStyleThicknessModifier_Material *)m)->value_max = 1.0f;
+ {
+ LineStyleThicknessModifier_Material *p = (LineStyleThicknessModifier_Material *)m;
+ p->curve = curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f);
+ p->mat_attr = LS_MODIFIER_MATERIAL_DIFF;
+ p->value_min = 0.0f;
+ p->value_max = 1.0f;
+ }
break;
case LS_MODIFIER_CALLIGRAPHY:
- ((LineStyleThicknessModifier_Calligraphy *)m)->min_thickness = 1.0f;
- ((LineStyleThicknessModifier_Calligraphy *)m)->max_thickness = 10.0f;
- ((LineStyleThicknessModifier_Calligraphy *)m)->orientation = DEG2RADF(60.0f);
+ {
+ LineStyleThicknessModifier_Calligraphy *p = (LineStyleThicknessModifier_Calligraphy *)m;
+ p->min_thickness = 1.0f;
+ p->max_thickness = 10.0f;
+ p->orientation = DEG2RADF(60.0f);
+ }
break;
default:
return NULL; /* unknown modifier type */
@@ -544,49 +567,54 @@ LineStyleModifier *FRS_copy_linestyle_thickness_modifier(FreestyleLineStyle *lin
case LS_MODIFIER_ALONG_STROKE:
{
LineStyleThicknessModifier_AlongStroke *p = (LineStyleThicknessModifier_AlongStroke *)m;
- ((LineStyleThicknessModifier_AlongStroke *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleThicknessModifier_AlongStroke *)new_m)->value_min = p->value_min;
- ((LineStyleThicknessModifier_AlongStroke *)new_m)->value_max = p->value_max;
+ LineStyleThicknessModifier_AlongStroke *q = (LineStyleThicknessModifier_AlongStroke *)new_m;
+ q->curve = curvemapping_copy(p->curve);
+ q->value_min = p->value_min;
+ q->value_max = p->value_max;
}
break;
case LS_MODIFIER_DISTANCE_FROM_CAMERA:
{
LineStyleThicknessModifier_DistanceFromCamera *p = (LineStyleThicknessModifier_DistanceFromCamera *)m;
- ((LineStyleThicknessModifier_DistanceFromCamera *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleThicknessModifier_DistanceFromCamera *)new_m)->range_min = p->range_min;
- ((LineStyleThicknessModifier_DistanceFromCamera *)new_m)->range_max = p->range_max;
- ((LineStyleThicknessModifier_DistanceFromCamera *)new_m)->value_min = p->value_min;
- ((LineStyleThicknessModifier_DistanceFromCamera *)new_m)->value_max = p->value_max;
+ LineStyleThicknessModifier_DistanceFromCamera *q = (LineStyleThicknessModifier_DistanceFromCamera *)new_m;
+ q->curve = curvemapping_copy(p->curve);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
+ q->value_min = p->value_min;
+ q->value_max = p->value_max;
}
break;
case LS_MODIFIER_DISTANCE_FROM_OBJECT:
{
LineStyleThicknessModifier_DistanceFromObject *p = (LineStyleThicknessModifier_DistanceFromObject *)m;
+ LineStyleThicknessModifier_DistanceFromObject *q = (LineStyleThicknessModifier_DistanceFromObject *)new_m;
if (p->target)
p->target->id.us++;
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->target = p->target;
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->range_min = p->range_min;
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->range_max = p->range_max;
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->value_min = p->value_min;
- ((LineStyleThicknessModifier_DistanceFromObject *)new_m)->value_max = p->value_max;
+ q->target = p->target;
+ q->curve = curvemapping_copy(p->curve);
+ q->range_min = p->range_min;
+ q->range_max = p->range_max;
+ q->value_min = p->value_min;
+ q->value_max = p->value_max;
}
break;
case LS_MODIFIER_MATERIAL:
{
LineStyleThicknessModifier_Material *p = (LineStyleThicknessModifier_Material *)m;
- ((LineStyleThicknessModifier_Material *)new_m)->curve = curvemapping_copy(p->curve);
- ((LineStyleThicknessModifier_Material *)new_m)->mat_attr = p->mat_attr;
- ((LineStyleThicknessModifier_Material *)new_m)->value_min = p->value_min;
- ((LineStyleThicknessModifier_Material *)new_m)->value_max = p->value_max;
+ LineStyleThicknessModifier_Material *q = (LineStyleThicknessModifier_Material *)new_m;
+ q->curve = curvemapping_copy(p->curve);
+ q->mat_attr = p->mat_attr;
+ q->value_min = p->value_min;
+ q->value_max = p->value_max;
}
break;
case LS_MODIFIER_CALLIGRAPHY:
{
LineStyleThicknessModifier_Calligraphy *p = (LineStyleThicknessModifier_Calligraphy *)m;
- ((LineStyleThicknessModifier_Calligraphy *)new_m)->min_thickness = p->min_thickness;
- ((LineStyleThicknessModifier_Calligraphy *)new_m)->max_thickness = p->max_thickness;
- ((LineStyleThicknessModifier_Calligraphy *)new_m)->orientation = p->orientation;
+ LineStyleThicknessModifier_Calligraphy *q = (LineStyleThicknessModifier_Calligraphy *)new_m;
+ q->min_thickness = p->min_thickness;
+ q->max_thickness = p->max_thickness;
+ q->orientation = p->orientation;
}
break;
default:
@@ -674,73 +702,110 @@ LineStyleModifier *FRS_add_linestyle_geometry_modifier(FreestyleLineStyle *lines
LineStyleModifier *m;
m = alloc_geometry_modifier(type);
- if (!m)
- return NULL;
switch (type) {
case LS_MODIFIER_SAMPLING:
- ((LineStyleGeometryModifier_Sampling *)m)->sampling = 10.0f;
+ {
+ LineStyleGeometryModifier_Sampling *p = (LineStyleGeometryModifier_Sampling *)m;
+ p->sampling = 10.0f;
+ }
break;
case LS_MODIFIER_BEZIER_CURVE:
- ((LineStyleGeometryModifier_BezierCurve *)m)->error = 10.0f;
+ {
+ LineStyleGeometryModifier_BezierCurve *p = (LineStyleGeometryModifier_BezierCurve *)m;
+ p->error = 10.0f;
+ }
break;
case LS_MODIFIER_SINUS_DISPLACEMENT:
- ((LineStyleGeometryModifier_SinusDisplacement *)m)->wavelength = 20.0f;
- ((LineStyleGeometryModifier_SinusDisplacement *)m)->amplitude = 5.0f;
- ((LineStyleGeometryModifier_SinusDisplacement *)m)->phase = 0.0f;
+ {
+ LineStyleGeometryModifier_SinusDisplacement *p = (LineStyleGeometryModifier_SinusDisplacement *)m;
+ p->wavelength = 20.0f;
+ p->amplitude = 5.0f;
+ p->phase = 0.0f;
+ }
break;
case LS_MODIFIER_SPATIAL_NOISE:
- ((LineStyleGeometryModifier_SpatialNoise *)m)->amplitude = 5.0f;
- ((LineStyleGeometryModifier_SpatialNoise *)m)->scale = 20.0f;
- ((LineStyleGeometryModifier_SpatialNoise *)m)->octaves = 4;
- ((LineStyleGeometryModifier_SpatialNoise *)m)->flags = LS_MODIFIER_SPATIAL_NOISE_SMOOTH | LS_MODIFIER_SPATIAL_NOISE_PURERANDOM;
+ {
+ LineStyleGeometryModifier_SpatialNoise *p = (LineStyleGeometryModifier_SpatialNoise *)m;
+ p->amplitude = 5.0f;
+ p->scale = 20.0f;
+ p->octaves = 4;
+ p->flags = LS_MODIFIER_SPATIAL_NOISE_SMOOTH | LS_MODIFIER_SPATIAL_NOISE_PURERANDOM;
+ }
break;
case LS_MODIFIER_PERLIN_NOISE_1D:
- ((LineStyleGeometryModifier_PerlinNoise1D *)m)->frequency = 10.0f;
- ((LineStyleGeometryModifier_PerlinNoise1D *)m)->amplitude = 10.0f;
- ((LineStyleGeometryModifier_PerlinNoise1D *)m)->octaves = 4;
- ((LineStyleGeometryModifier_PerlinNoise1D *)m)->angle = DEG2RADF(45.0f);
+ {
+ LineStyleGeometryModifier_PerlinNoise1D *p = (LineStyleGeometryModifier_PerlinNoise1D *)m;
+ p->frequency = 10.0f;
+ p->amplitude = 10.0f;
+ p->octaves = 4;
+ p->angle = DEG2RADF(45.0f);
+ }
break;
case LS_MODIFIER_PERLIN_NOISE_2D:
- ((LineStyleGeometryModifier_PerlinNoise2D *)m)->frequency = 10.0f;
- ((LineStyleGeometryModifier_PerlinNoise2D *)m)->amplitude = 10.0f;
- ((LineStyleGeometryModifier_PerlinNoise2D *)m)->octaves = 4;
- ((LineStyleGeometryModifier_PerlinNoise2D *)m)->angle = DEG2RADF(45.0f);
+ {
+ LineStyleGeometryModifier_PerlinNoise2D *p = (LineStyleGeometryModifier_PerlinNoise2D *)m;
+ p->frequency = 10.0f;
+ p->amplitude = 10.0f;
+ p->octaves = 4;
+ p->angle = DEG2RADF(45.0f);
+ }
break;
case LS_MODIFIER_BACKBONE_STRETCHER:
- ((LineStyleGeometryModifier_BackboneStretcher *)m)->backbone_length = 10.0f;
+ {
+ LineStyleGeometryModifier_BackboneStretcher *p = (LineStyleGeometryModifier_BackboneStretcher *)m;
+ p->backbone_length = 10.0f;
+ }
break;
case LS_MODIFIER_TIP_REMOVER:
- ((LineStyleGeometryModifier_TipRemover *)m)->tip_length = 10.0f;
+ {
+ LineStyleGeometryModifier_TipRemover *p = (LineStyleGeometryModifier_TipRemover *)m;
+ p->tip_length = 10.0f;
+ }
break;
case LS_MODIFIER_POLYGONIZATION:
- ((LineStyleGeometryModifier_Polygonalization *)m)->error = 10.0f;
+ {
+ LineStyleGeometryModifier_Polygonalization *p = (LineStyleGeometryModifier_Polygonalization *)m;
+ p->error = 10.0f;
+ }
break;
case LS_MODIFIER_GUIDING_LINES:
- ((LineStyleGeometryModifier_GuidingLines *)m)->offset = 0.0f;
+ {
+ LineStyleGeometryModifier_GuidingLines *p = (LineStyleGeometryModifier_GuidingLines *)m;
+ p->offset = 0.0f;
+ }
break;
case LS_MODIFIER_BLUEPRINT:
- ((LineStyleGeometryModifier_Blueprint *)m)->flags = LS_MODIFIER_BLUEPRINT_CIRCLES;
- ((LineStyleGeometryModifier_Blueprint *)m)->rounds = 1;
- ((LineStyleGeometryModifier_Blueprint *)m)->backbone_length = 10.0f;
- ((LineStyleGeometryModifier_Blueprint *)m)->random_radius = 3;
- ((LineStyleGeometryModifier_Blueprint *)m)->random_center = 5;
- ((LineStyleGeometryModifier_Blueprint *)m)->random_backbone = 5;
+ {
+ LineStyleGeometryModifier_Blueprint *p = (LineStyleGeometryModifier_Blueprint *)m;
+ p->flags = LS_MODIFIER_BLUEPRINT_CIRCLES;
+ p->rounds = 1;
+ p->backbone_length = 10.0f;
+ p->random_radius = 3;
+ p->random_center = 5;
+ p->random_backbone = 5;
+ }
break;
case LS_MODIFIER_2D_OFFSET:
- ((LineStyleGeometryModifier_2DOffset *)m)->start = 0.0f;
- ((LineStyleGeometryModifier_2DOffset *)m)->end = 0.0f;
- ((LineStyleGeometryModifier_2DOffset *)m)->x = 0.0f;
- ((LineStyleGeometryModifier_2DOffset *)m)->y = 0.0f;
+ {
+ LineStyleGeometryModifier_2DOffset *p = (LineStyleGeometryModifier_2DOffset *)m;
+ p->start = 0.0f;
+ p->end = 0.0f;
+ p->x = 0.0f;
+ p->y = 0.0f;
+ }
break;
case LS_MODIFIER_2D_TRANSFORM:
- ((LineStyleGeometryModifier_2DTransform *)m)->pivot = LS_MODIFIER_2D_TRANSFORM_PIVOT_CENTER;
- ((LineStyleGeometryModifier_2DTransform *)m)->scale_x = 1.0f;
- ((LineStyleGeometryModifier_2DTransform *)m)->scale_y = 1.0f;
- ((LineStyleGeometryModifier_2DTransform *)m)->angle = DEG2RADF(0.0f);
- ((LineStyleGeometryModifier_2DTransform *)m)->pivot_u = 0.5f;
- ((LineStyleGeometryModifier_2DTransform *)m)->pivot_x = 0.0f;
- ((LineStyleGeometryModifier_2DTransform *)m)->pivot_y = 0.0f;
+ {
+ LineStyleGeometryModifier_2DTransform *p = (LineStyleGeometryModifier_2DTransform *)m;
+ p->pivot = LS_MODIFIER_2D_TRANSFORM_PIVOT_CENTER;
+ p->scale_x = 1.0f;
+ p->scale_y = 1.0f;
+ p->angle = DEG2RADF(0.0f);
+ p->pivot_u = 0.5f;
+ p->pivot_x = 0.0f;
+ p->pivot_y = 0.0f;
+ }
break;
default:
return NULL; /* unknown modifier type */
@@ -755,112 +820,123 @@ LineStyleModifier *FRS_copy_linestyle_geometry_modifier(FreestyleLineStyle *line
LineStyleModifier *new_m;
new_m = alloc_geometry_modifier(m->type);
- if (!new_m)
- return NULL;
new_m->flags = m->flags;
switch (m->type) {
case LS_MODIFIER_SAMPLING:
{
LineStyleGeometryModifier_Sampling *p = (LineStyleGeometryModifier_Sampling *)m;
- ((LineStyleGeometryModifier_Sampling *)new_m)->sampling = p->sampling;
+ LineStyleGeometryModifier_Sampling *q = (LineStyleGeometryModifier_Sampling *)new_m;
+ q->sampling = p->sampling;
}
break;
case LS_MODIFIER_BEZIER_CURVE:
{
LineStyleGeometryModifier_BezierCurve *p = (LineStyleGeometryModifier_BezierCurve *)m;
- ((LineStyleGeometryModifier_BezierCurve *)new_m)->error = p->error;
+ LineStyleGeometryModifier_BezierCurve *q = (LineStyleGeometryModifier_BezierCurve *)new_m;
+ q->error = p->error;
}
break;
case LS_MODIFIER_SINUS_DISPLACEMENT:
{
LineStyleGeometryModifier_SinusDisplacement *p = (LineStyleGeometryModifier_SinusDisplacement *)m;
- ((LineStyleGeometryModifier_SinusDisplacement *)new_m)->wavelength = p->wavelength;
- ((LineStyleGeometryModifier_SinusDisplacement *)new_m)->amplitude = p->amplitude;
- ((LineStyleGeometryModifier_SinusDisplacement *)new_m)->phase = p->phase;
+ LineStyleGeometryModifier_SinusDisplacement *q = (LineStyleGeometryModifier_SinusDisplacement *)new_m;
+ q->wavelength = p->wavelength;
+ q->amplitude = p->amplitude;
+ q->phase = p->phase;
}
break;
case LS_MODIFIER_SPATIAL_NOISE:
{
LineStyleGeometryModifier_SpatialNoise *p = (LineStyleGeometryModifier_SpatialNoise *)m;
- ((LineStyleGeometryModifier_SpatialNoise *)new_m)->amplitude = p->amplitude;
- ((LineStyleGeometryModifier_SpatialNoise *)new_m)->scale = p->scale;
- ((LineStyleGeometryModifier_SpatialNoise *)new_m)->octaves = p->octaves;
- ((LineStyleGeometryModifier_SpatialNoise *)new_m)->flags = p->flags;
+ LineStyleGeometryModifier_SpatialNoise *q = (LineStyleGeometryModifier_SpatialNoise *)new_m;
+ q->amplitude = p->amplitude;
+ q->scale = p->scale;
+ q->octaves = p->octaves;
+ q->flags = p->flags;
}
break;
case LS_MODIFIER_PERLIN_NOISE_1D:
{
LineStyleGeometryModifier_PerlinNoise1D *p = (LineStyleGeometryModifier_PerlinNoise1D *)m;
- ((LineStyleGeometryModifier_PerlinNoise1D *)new_m)->frequency = p->frequency;
- ((LineStyleGeometryModifier_PerlinNoise1D *)new_m)->amplitude = p->amplitude;
- ((LineStyleGeometryModifier_PerlinNoise1D *)new_m)->octaves = p->octaves;
- ((LineStyleGeometryModifier_PerlinNoise1D *)new_m)->angle = p->angle;
+ LineStyleGeometryModifier_PerlinNoise1D *q = (LineStyleGeometryModifier_PerlinNoise1D *)new_m;
+ q->frequency = p->frequency;
+ q->amplitude = p->amplitude;
+ q->octaves = p->octaves;
+ q->angle = p->angle;
}
break;
case LS_MODIFIER_PERLIN_NOISE_2D:
{
LineStyleGeometryModifier_PerlinNoise2D *p = (LineStyleGeometryModifier_PerlinNoise2D *)m;
- ((LineStyleGeometryModifier_PerlinNoise2D *)new_m)->frequency = p->frequency;
- ((LineStyleGeometryModifier_PerlinNoise2D *)new_m)->amplitude = p->amplitude;
- ((LineStyleGeometryModifier_PerlinNoise2D *)new_m)->octaves = p->octaves;
- ((LineStyleGeometryModifier_PerlinNoise2D *)new_m)->angle = p->angle;
+ LineStyleGeometryModifier_PerlinNoise2D *q = (LineStyleGeometryModifier_PerlinNoise2D *)new_m;
+ q->frequency = p->frequency;
+ q->amplitude = p->amplitude;
+ q->octaves = p->octaves;
+ q->angle = p->angle;
}
break;
case LS_MODIFIER_BACKBONE_STRETCHER:
{
LineStyleGeometryModifier_BackboneStretcher *p = (LineStyleGeometryModifier_BackboneStretcher *)m;
- ((LineStyleGeometryModifier_BackboneStretcher *)new_m)->backbone_length = p->backbone_length;
+ LineStyleGeometryModifier_BackboneStretcher *q = (LineStyleGeometryModifier_BackboneStretcher *)new_m;
+ q->backbone_length = p->backbone_length;
}
break;
case LS_MODIFIER_TIP_REMOVER:
{
LineStyleGeometryModifier_TipRemover *p = (LineStyleGeometryModifier_TipRemover *)m;
- ((LineStyleGeometryModifier_TipRemover *)new_m)->tip_length = p->tip_length;
+ LineStyleGeometryModifier_TipRemover *q = (LineStyleGeometryModifier_TipRemover *)new_m;
+ q->tip_length = p->tip_length;
}
break;
case LS_MODIFIER_POLYGONIZATION:
{
LineStyleGeometryModifier_Polygonalization *p = (LineStyleGeometryModifier_Polygonalization *)m;
- ((LineStyleGeometryModifier_Polygonalization *)new_m)->error = p->error;
+ LineStyleGeometryModifier_Polygonalization *q = (LineStyleGeometryModifier_Polygonalization *)new_m;
+ q->error = p->error;
}
break;
case LS_MODIFIER_GUIDING_LINES:
{
LineStyleGeometryModifier_GuidingLines *p = (LineStyleGeometryModifier_GuidingLines *)m;
- ((LineStyleGeometryModifier_GuidingLines *)new_m)->offset = p->offset;
+ LineStyleGeometryModifier_GuidingLines *q = (LineStyleGeometryModifier_GuidingLines *)new_m;
+ q->offset = p->offset;
}
break;
case LS_MODIFIER_BLUEPRINT:
{
LineStyleGeometryModifier_Blueprint *p = (LineStyleGeometryModifier_Blueprint *)m;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->flags = p->flags;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->rounds = p->rounds;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->backbone_length = p->backbone_length;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->random_radius = p->random_radius;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->random_center = p->random_center;
- ((LineStyleGeometryModifier_Blueprint *)new_m)->random_backbone = p->random_backbone;
+ LineStyleGeometryModifier_Blueprint *q = (LineStyleGeometryModifier_Blueprint *)new_m;
+ q->flags = p->flags;
+ q->rounds = p->rounds;
+ q->backbone_length = p->backbone_length;
+ q->random_radius = p->random_radius;
+ q->random_center = p->random_center;
+ q->random_backbone = p->random_backbone;
}
break;
case LS_MODIFIER_2D_OFFSET:
{
LineStyleGeometryModifier_2DOffset *p = (LineStyleGeometryModifier_2DOffset *)m;
- ((LineStyleGeometryModifier_2DOffset *)new_m)->start = p->start;
- ((LineStyleGeometryModifier_2DOffset *)new_m)->end = p->end;
- ((LineStyleGeometryModifier_2DOffset *)new_m)->x = p->x;
- ((LineStyleGeometryModifier_2DOffset *)new_m)->y = p->y;
+ LineStyleGeometryModifier_2DOffset *q = (LineStyleGeometryModifier_2DOffset *)new_m;
+ q->start = p->start;
+ q->end = p->end;
+ q->x = p->x;
+ q->y = p->y;
}
break;
case LS_MODIFIER_2D_TRANSFORM:
{
LineStyleGeometryModifier_2DTransform *p = (LineStyleGeometryModifier_2DTransform *)m;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->pivot = p->pivot;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->scale_x = p->scale_x;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->scale_y = p->scale_y;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->angle = p->angle;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->pivot_u = p->pivot_u;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->pivot_x = p->pivot_x;
- ((LineStyleGeometryModifier_2DTransform *)new_m)->pivot_y = p->pivot_y;
+ LineStyleGeometryModifier_2DTransform *q = (LineStyleGeometryModifier_2DTransform *)new_m;
+ q->pivot = p->pivot;
+ q->scale_x = p->scale_x;
+ q->scale_y = p->scale_y;
+ q->angle = p->angle;
+ q->pivot_u = p->pivot_u;
+ q->pivot_x = p->pivot_x;
+ q->pivot_y = p->pivot_y;
}
break;
default:
@@ -873,34 +949,6 @@ LineStyleModifier *FRS_copy_linestyle_geometry_modifier(FreestyleLineStyle *line
void FRS_remove_linestyle_geometry_modifier(FreestyleLineStyle *linestyle, LineStyleModifier *m)
{
- switch (m->type) {
- case LS_MODIFIER_SAMPLING:
- break;
- case LS_MODIFIER_BEZIER_CURVE:
- break;
- case LS_MODIFIER_SINUS_DISPLACEMENT:
- break;
- case LS_MODIFIER_SPATIAL_NOISE:
- break;
- case LS_MODIFIER_PERLIN_NOISE_1D:
- break;
- case LS_MODIFIER_PERLIN_NOISE_2D:
- break;
- case LS_MODIFIER_BACKBONE_STRETCHER:
- break;
- case LS_MODIFIER_TIP_REMOVER:
- break;
- case LS_MODIFIER_POLYGONIZATION:
- break;
- case LS_MODIFIER_GUIDING_LINES:
- break;
- case LS_MODIFIER_BLUEPRINT:
- break;
- case LS_MODIFIER_2D_OFFSET:
- break;
- case LS_MODIFIER_2D_TRANSFORM:
- break;
- }
BLI_freelinkN(&linestyle->geometry_modifiers, m);
}