rename NOTEQUAL as NOTEQ

since <= is LESSEQ

python has some relational overloads now
This commit is contained in:
John Cupitt 2014-09-16 17:25:20 +01:00
parent 65a062e4a1
commit de594151a5
6 changed files with 49 additions and 17 deletions

View File

@ -7,6 +7,8 @@
- add @background arg to save: the colour to flatten against - add @background arg to save: the colour to flatten against
- add VIPS_ARGUMENT_MODIFY flag ... used for draw_circle etc, meaning an op - add VIPS_ARGUMENT_MODIFY flag ... used for draw_circle etc, meaning an op
which modifies its argument which modifies its argument
- rename VIPS_OPERATION_RELATIONAL_NOTEQUAL as VIPS_OPERATION_RELATIONAL_NOTEQ
for consistency
8/9/14 started 7.40.9 8/9/14 started 7.40.9
- support jfif resunit "none" - support jfif resunit "none"

View File

@ -149,7 +149,7 @@ vips_relational_build( VipsObject *object )
} }
#define CEQUAL( x1, y1, x2, y2 ) (x1 == x2 && y1 == y2) #define CEQUAL( x1, y1, x2, y2 ) (x1 == x2 && y1 == y2)
#define CNOTEQUAL( x1, y1, x2, y2 ) (x1 != x2 || y1 != y2) #define CNOTEQ( x1, y1, x2, y2 ) (x1 != x2 || y1 != y2)
#define CLESS( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 < x2 * x2 + y2 * y2) #define CLESS( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 < x2 * x2 + y2 * y2)
#define CLESSEQ( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 <= x2 * x2 + y2 * y2) #define CLESSEQ( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 <= x2 * x2 + y2 * y2)
#define CMORE( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 > x2 * x2 + y2 * y2) #define CMORE( x1, y1, x2, y2 ) (x1 * x1 + y1 * y1 > x2 * x2 + y2 * y2)
@ -170,8 +170,8 @@ vips_relational_buffer( VipsArithmetic *arithmetic,
SWITCH( RLOOP, CLOOP, ==, CEQUAL ); SWITCH( RLOOP, CLOOP, ==, CEQUAL );
break; break;
case VIPS_OPERATION_RELATIONAL_NOTEQUAL: case VIPS_OPERATION_RELATIONAL_NOTEQ:
SWITCH( RLOOP, CLOOP, !=, CNOTEQUAL ); SWITCH( RLOOP, CLOOP, !=, CNOTEQ );
break; break;
case VIPS_OPERATION_RELATIONAL_LESS: case VIPS_OPERATION_RELATIONAL_LESS:
@ -327,7 +327,7 @@ vips_equal( VipsImage *left, VipsImage *right, VipsImage **out, ... )
* @out: output #VipsImage * @out: output #VipsImage
* @...: %NULL-terminated list of optional named arguments * @...: %NULL-terminated list of optional named arguments
* *
* Perform #VIPS_OPERATION_RELATIONAL_NOTEQUAL on a pair of images. See * Perform #VIPS_OPERATION_RELATIONAL_NOTEQ on a pair of images. See
* vips_relational(). * vips_relational().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
@ -340,7 +340,7 @@ vips_notequal( VipsImage *left, VipsImage *right, VipsImage **out, ... )
va_start( ap, out ); va_start( ap, out );
result = vips_relationalv( left, right, out, result = vips_relationalv( left, right, out,
VIPS_OPERATION_RELATIONAL_NOTEQUAL, ap ); VIPS_OPERATION_RELATIONAL_NOTEQ, ap );
va_end( ap ); va_end( ap );
return( result ); return( result );
@ -517,8 +517,8 @@ vips_relational_const_buffer( VipsArithmetic *arithmetic,
SWITCH( RLOOPC, CLOOPC, ==, CEQUAL ); SWITCH( RLOOPC, CLOOPC, ==, CEQUAL );
break; break;
case VIPS_OPERATION_RELATIONAL_NOTEQUAL: case VIPS_OPERATION_RELATIONAL_NOTEQ:
SWITCH( RLOOPC, CLOOPC, !=, CNOTEQUAL ); SWITCH( RLOOPC, CLOOPC, !=, CNOTEQ );
break; break;
case VIPS_OPERATION_RELATIONAL_LESS: case VIPS_OPERATION_RELATIONAL_LESS:
@ -672,7 +672,7 @@ vips_equal_const( VipsImage *in, VipsImage **out, double *c, int n, ... )
* @n: number of constants in @c * @n: number of constants in @c
* @...: %NULL-terminated list of optional named arguments * @...: %NULL-terminated list of optional named arguments
* *
* Perform #VIPS_OPERATION_RELATIONAL_NOTEQUAL on an image and a constant. See * Perform #VIPS_OPERATION_RELATIONAL_NOTEQ on an image and a constant. See
* vips_relational_const(). * vips_relational_const().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
@ -685,7 +685,7 @@ vips_notequal_const( VipsImage *in, VipsImage **out, double *c, int n, ... )
va_start( ap, n ); va_start( ap, n );
result = vips_relational_constv( in, out, result = vips_relational_constv( in, out,
VIPS_OPERATION_RELATIONAL_NOTEQUAL, c, n, ap ); VIPS_OPERATION_RELATIONAL_NOTEQ, c, n, ap );
va_end( ap ); va_end( ap );
return( result ); return( result );
@ -861,7 +861,7 @@ vips_equal_const1( VipsImage *in, VipsImage **out, double c, ... )
* @c: constant * @c: constant
* @...: %NULL-terminated list of optional named arguments * @...: %NULL-terminated list of optional named arguments
* *
* Perform #VIPS_OPERATION_RELATIONAL_NOTEQUAL on an image and a constant. See * Perform #VIPS_OPERATION_RELATIONAL_NOTEQ on an image and a constant. See
* vips_relational_const(). * vips_relational_const().
* *
* Returns: 0 on success, -1 on error * Returns: 0 on success, -1 on error
@ -874,7 +874,7 @@ vips_notequal_const1( VipsImage *in, VipsImage **out, double c, ... )
va_start( ap, c ); va_start( ap, c );
result = vips_relational_constv( in, out, result = vips_relational_constv( in, out,
VIPS_OPERATION_RELATIONAL_NOTEQUAL, &c, 1, ap ); VIPS_OPERATION_RELATIONAL_NOTEQ, &c, 1, ap );
va_end( ap ); va_end( ap );
return( result ); return( result );

View File

@ -2631,7 +2631,7 @@ int
im_notequal( IMAGE *in1, IMAGE *in2, IMAGE *out ) im_notequal( IMAGE *in1, IMAGE *in2, IMAGE *out )
{ {
return( vips__relational( in1, in2, out, return( vips__relational( in1, in2, out,
VIPS_OPERATION_RELATIONAL_NOTEQUAL ) ); VIPS_OPERATION_RELATIONAL_NOTEQ ) );
} }
int int
@ -2691,7 +2691,7 @@ int
im_notequal_vec( VipsImage *in, VipsImage *out, int n, double *c ) im_notequal_vec( VipsImage *in, VipsImage *out, int n, double *c )
{ {
return( vips__relational_vec( in, out, return( vips__relational_vec( in, out,
VIPS_OPERATION_RELATIONAL_NOTEQUAL, c, n ) ); VIPS_OPERATION_RELATIONAL_NOTEQ, c, n ) );
} }
int int

View File

@ -98,7 +98,7 @@ typedef enum {
/** /**
* VipsOperationRelational: * VipsOperationRelational:
* @VIPS_OPERATION_RELATIONAL_EQUAL: == * @VIPS_OPERATION_RELATIONAL_EQUAL: ==
* @VIPS_OPERATION_RELATIONAL_NOTEQUAL: != * @VIPS_OPERATION_RELATIONAL_NOTEQ: !=
* @VIPS_OPERATION_RELATIONAL_LESS: < * @VIPS_OPERATION_RELATIONAL_LESS: <
* @VIPS_OPERATION_RELATIONAL_LESSEQ: <= * @VIPS_OPERATION_RELATIONAL_LESSEQ: <=
* @VIPS_OPERATION_RELATIONAL_MORE: > * @VIPS_OPERATION_RELATIONAL_MORE: >
@ -108,7 +108,7 @@ typedef enum {
*/ */
typedef enum { typedef enum {
VIPS_OPERATION_RELATIONAL_EQUAL, VIPS_OPERATION_RELATIONAL_EQUAL,
VIPS_OPERATION_RELATIONAL_NOTEQUAL, VIPS_OPERATION_RELATIONAL_NOTEQ,
VIPS_OPERATION_RELATIONAL_LESS, VIPS_OPERATION_RELATIONAL_LESS,
VIPS_OPERATION_RELATIONAL_LESSEQ, VIPS_OPERATION_RELATIONAL_LESSEQ,
VIPS_OPERATION_RELATIONAL_MORE, VIPS_OPERATION_RELATIONAL_MORE,

View File

@ -337,7 +337,7 @@ vips_operation_relational_get_type( void )
if( etype == 0 ) { if( etype == 0 ) {
static const GEnumValue values[] = { static const GEnumValue values[] = {
{VIPS_OPERATION_RELATIONAL_EQUAL, "VIPS_OPERATION_RELATIONAL_EQUAL", "equal"}, {VIPS_OPERATION_RELATIONAL_EQUAL, "VIPS_OPERATION_RELATIONAL_EQUAL", "equal"},
{VIPS_OPERATION_RELATIONAL_NOTEQUAL, "VIPS_OPERATION_RELATIONAL_NOTEQUAL", "notequal"}, {VIPS_OPERATION_RELATIONAL_NOTEQ, "VIPS_OPERATION_RELATIONAL_NOTEQ", "noteq"},
{VIPS_OPERATION_RELATIONAL_LESS, "VIPS_OPERATION_RELATIONAL_LESS", "less"}, {VIPS_OPERATION_RELATIONAL_LESS, "VIPS_OPERATION_RELATIONAL_LESS", "less"},
{VIPS_OPERATION_RELATIONAL_LESSEQ, "VIPS_OPERATION_RELATIONAL_LESSEQ", "lesseq"}, {VIPS_OPERATION_RELATIONAL_LESSEQ, "VIPS_OPERATION_RELATIONAL_LESSEQ", "lesseq"},
{VIPS_OPERATION_RELATIONAL_MORE, "VIPS_OPERATION_RELATIONAL_MORE", "more"}, {VIPS_OPERATION_RELATIONAL_MORE, "VIPS_OPERATION_RELATIONAL_MORE", "more"},

View File

@ -132,7 +132,7 @@ def _call_base(name, required, optional, self = None, option_string = None):
# do we have a non-None self pointer? this is used to set the first # do we have a non-None self pointer? this is used to set the first
# compatible input arg # compatible input arg
if self != None: if self is not None:
found = False found = False
for x in required_input: for x in required_input:
if GObject.type_is_a(self, x.prop.value_type): if GObject.type_is_a(self, x.prop.value_type):
@ -424,6 +424,36 @@ def vips_more(self, other):
else: else:
return self.relational_const(Vips.OperationRelational.MORE, other) return self.relational_const(Vips.OperationRelational.MORE, other)
def vips_moreeq(self, other):
if isinstance(other, Vips.Image):
return self.relational(other, Vips.OperationRelational.MOREEQ)
else:
return self.relational_const(Vips.OperationRelational.MOREEQ, other)
def vips_less(self, other):
if isinstance(other, Vips.Image):
return self.relational(other, Vips.OperationRelational.MORE)
else:
return self.relational_const(Vips.OperationRelational.MORE, other)
def vips_lesseq(self, other):
if isinstance(other, Vips.Image):
return self.relational(other, Vips.OperationRelational.LESSEQ)
else:
return self.relational_const(Vips.OperationRelational.LESSEQ, other)
def vips_equal(self, other):
if isinstance(other, Vips.Image):
return self.relational(other, Vips.OperationRelational.EQUAL)
else:
return self.relational_const(Vips.OperationRelational.EQUAL, other)
def vips_notequal(self, other):
if isinstance(other, Vips.Image):
return self.relational(other, Vips.OperationRelational.NOTEQ)
else:
return self.relational_const(Vips.OperationRelational.NOTEQ, other)
def vips_neg(self): def vips_neg(self):
return -1 * self return -1 * self