Skip to content

Commit

Permalink
Factorize some code in the filters.
Browse files Browse the repository at this point in the history
  • Loading branch information
antoinecellerier committed Jun 4, 2008
1 parent b6dc08d commit 2085fb0
Show file tree
Hide file tree
Showing 18 changed files with 34 additions and 178 deletions.
22 changes: 2 additions & 20 deletions modules/video_filter/adjust.c
Original file line number Diff line number Diff line change
Expand Up @@ -410,16 +410,7 @@ static picture_t *FilterPlanar( filter_t *p_filter, picture_t *p_pic )
#undef WRITE_UV
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down Expand Up @@ -652,16 +643,7 @@ static picture_t *FilterPacked( filter_t *p_filter, picture_t *p_pic )
#undef WRITE_UV
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

static int AdjustCallback( vlc_object_t *p_this, char const *psz_var,
Expand Down
11 changes: 1 addition & 10 deletions modules/video_filter/colorthres.c
Original file line number Diff line number Diff line change
Expand Up @@ -228,14 +228,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
p_out_v++;
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
11 changes: 2 additions & 9 deletions modules/video_filter/croppadd.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
#include <vlc_plugin.h>
#include <vlc_vout.h>
#include "vlc_filter.h"
#include "filter_picture.h"

/****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -187,13 +188,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
( i_outheight - i_ypadd - i_height ) * p_outplane->i_pitch );
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
12 changes: 2 additions & 10 deletions modules/video_filter/erase.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
#include "vlc_image.h"

#include "vlc_filter.h"
#include "filter_picture.h"

/*****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -216,16 +217,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
/* Here */
FilterErase( p_filter, p_pic, p_outpic );

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down
11 changes: 1 addition & 10 deletions modules/video_filter/extract.c
Original file line number Diff line number Diff line change
Expand Up @@ -250,16 +250,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
return NULL;
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

static inline uint8_t crop( int a )
Expand Down
2 changes: 1 addition & 1 deletion modules/video_filter/filter_picture.h
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ static inline int GetPackedYuvOffsets( vlc_fourcc_t i_chroma,
/*****************************************************************************
*
*****************************************************************************/
static inline picture_t *CopyMetaAndRelease( picture_t *p_outpic, picture_t *p_inpic )
static inline picture_t *CopyInfoAndRelease( picture_t *p_outpic, picture_t *p_inpic )
{
p_outpic->date = p_inpic->date;
p_outpic->b_force = p_inpic->b_force;
Expand Down
12 changes: 2 additions & 10 deletions modules/video_filter/gaussianblur.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
#include <vlc_vout.h>

#include "vlc_filter.h"
#include "filter_picture.h"

#include <math.h> /* exp(), sqrt() */

Expand Down Expand Up @@ -377,14 +378,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
}
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
11 changes: 1 addition & 10 deletions modules/video_filter/gradient.c
Original file line number Diff line number Diff line change
Expand Up @@ -263,16 +263,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
break;
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down
11 changes: 1 addition & 10 deletions modules/video_filter/grain.c
Original file line number Diff line number Diff line change
Expand Up @@ -203,14 +203,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )

}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
12 changes: 2 additions & 10 deletions modules/video_filter/invert.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
#include <vlc_vout.h>

#include "vlc_filter.h"
#include "filter_picture.h"

/*****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -181,14 +182,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
}
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
19 changes: 4 additions & 15 deletions modules/video_filter/motionblur.c
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
#include <vlc_sout.h>
#include <vlc_vout.h>
#include <vlc_filter.h>
#include "filter_picture.h"

/*****************************************************************************
* Local protypes
Expand Down Expand Up @@ -129,17 +130,6 @@ static void Destroy( vlc_object_t *p_this )
free( p_filter->p_sys );
}

#define RELEASE( pic ) \
if( pic ->pf_release ) \
pic ->pf_release( pic );

#define INITPIC( dst, src ) \
dst ->date = src ->date; \
dst ->b_force = src ->b_force; \
dst ->i_nb_fields = src ->i_nb_fields; \
dst ->b_progressive = src->b_progressive; \
dst ->b_top_field_first = src ->b_top_field_first;

/*****************************************************************************
* Filter
*****************************************************************************/
Expand All @@ -154,10 +144,10 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
if( !p_outpic )
{
msg_Warn( p_filter, "can't get output picture" );
RELEASE( p_pic );
if( p_pic->pf_release )
p_pic->pf_release( p_pic );
return NULL;
}
INITPIC( p_outpic, p_pic );

if( !p_sys->pp_planes )
{
Expand All @@ -178,8 +168,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
RenderBlur( p_sys, p_pic, p_outpic );
Copy( p_filter, p_outpic );

RELEASE( p_pic );
return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down
12 changes: 2 additions & 10 deletions modules/video_filter/noise.c
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
#include <vlc_vout.h>

#include "vlc_filter.h"
#include "filter_picture.h"

/*****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -171,14 +172,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
}
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
12 changes: 2 additions & 10 deletions modules/video_filter/psychedelic.c
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@

#include "vlc_filter.h"
#include "vlc_image.h"
#include "filter_picture.h"

/*****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -252,14 +253,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
p_filter->p_sys->v += 1;
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
12 changes: 2 additions & 10 deletions modules/video_filter/ripple.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
#include <vlc_plugin.h>
#include <vlc_vout.h>
#include <vlc_filter.h>
#include "filter_picture.h"

/*****************************************************************************
* Local prototypes
Expand Down Expand Up @@ -203,14 +204,5 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
}
}

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}
4 changes: 2 additions & 2 deletions modules/video_filter/rotate.c
Original file line number Diff line number Diff line change
Expand Up @@ -283,7 +283,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )
}
}

return CopyMetaAndRelease( p_outpic, p_pic );
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down Expand Up @@ -385,7 +385,7 @@ static picture_t *FilterPacked( filter_t *p_filter, picture_t *p_pic )
}
}

return CopyMetaAndRelease( p_outpic, p_pic );
return CopyInfoAndRelease( p_outpic, p_pic );
}

/*****************************************************************************
Expand Down
12 changes: 2 additions & 10 deletions modules/video_filter/seamcarving.c
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@
#include <vlc_vout.h>

#include "vlc_filter.h"
#include "filter_picture.h"

#include <assert.h>

Expand Down Expand Up @@ -126,16 +127,7 @@ static picture_t *Filter( filter_t *p_filter, picture_t *p_pic )

FilterSeamCarving( p_filter, p_pic, p_outpic );

p_outpic->date = p_pic->date;
p_outpic->b_force = p_pic->b_force;
p_outpic->i_nb_fields = p_pic->i_nb_fields;
p_outpic->b_progressive = p_pic->b_progressive;
p_outpic->b_top_field_first = p_pic->b_top_field_first;

if( p_pic->pf_release )
p_pic->pf_release( p_pic );

return p_outpic;
return CopyInfoAndRelease( p_outpic, p_pic );
}

static inline int my_min3( int a, int b, int c );
Expand Down
Loading

0 comments on commit 2085fb0

Please sign in to comment.