Fix compatibility with Makefile

+ all operations are now provided with a C++ style comment block.
This commit is contained in:
kleisauke 2019-02-03 12:13:04 +01:00
parent de27688eea
commit 241f52fb54
5 changed files with 4928 additions and 3089 deletions

View File

@ -25,8 +25,7 @@ vips-operators.cpp:
echo -n "// " >> vips-operators.cpp; \ echo -n "// " >> vips-operators.cpp; \
date >> vips-operators.cpp; \ date >> vips-operators.cpp; \
echo "// this file is generated automatically, do not edit!" >> vips-operators.cpp; \ echo "// this file is generated automatically, do not edit!" >> vips-operators.cpp; \
echo "" >> vips-operators.cpp; \ ./gen-operators.py -g cpp >> vips-operators.cpp
./gen-operators.py >> vips-operators.cpp
EXTRA_DIST = \ EXTRA_DIST = \
README \ README \

View File

@ -28,7 +28,7 @@
# return( out ); # return( out );
# } # }
import datetime import argparse
from pyvips import Image, Operation, GValue, Error, \ from pyvips import Image, Operation, GValue, Error, \
ffi, gobject_lib, type_map, type_from_name, nickname_find, type_name ffi, gobject_lib, type_map, type_from_name, nickname_find, type_name
@ -41,7 +41,6 @@ gtype_to_cpp = {
GValue.gstr_type: 'char *', GValue.gstr_type: 'char *',
GValue.refstr_type: 'char *', GValue.refstr_type: 'char *',
GValue.gflags_type: 'int', GValue.gflags_type: 'int',
GValue.gobject_type: 'char *',
GValue.image_type: 'VImage', GValue.image_type: 'VImage',
GValue.array_int_type: 'std::vector<int>', GValue.array_int_type: 'std::vector<int>',
GValue.array_double_type: 'std::vector<double>', GValue.array_double_type: 'std::vector<double>',
@ -114,16 +113,30 @@ def generate_operation(operation_name, declaration_only=False):
has_output = len(required_output) >= 1 has_output = len(required_output) >= 1
# TODO: Should we output the operation description as comment? # Add a C++ style comment block with some additional markings (@param, @return)
# if declaration_only: if declaration_only:
# description = op.get_description() description = op.get_description()
#
# result = '\n\n/*\n' result = '\n/**\n'
# result += ' ' + description[0].upper() + description[1:] + '.\n' result += ' * ' + description[0].upper() + description[1:] + '.'
# result += '*/\n'
# else: for name in required_input:
result += '\n * @param ' + cppize(name) + ' ' + op.get_blurb(name) + '.'
if has_output:
# skip the first element
for name in required_output[1:]:
result += '\n * @param ' + cppize(name) + ' ' + op.get_blurb(name) + '.'
result += '\n * @param options Optional options.'
if has_output:
result += '\n * @return ' + op.get_blurb(required_output[0]) + '.'
result += '\n */\n'
else:
result = '\n'
result = '\n'
if member_x is None and declaration_only: if member_x is None and declaration_only:
result += 'static ' result += 'static '
if has_output: if has_output:
@ -201,20 +214,12 @@ def generate_operation(operation_name, declaration_only=False):
result += '\n' result += '\n'
result += ' return( {0} );\n'.format(required_output[0]) result += ' return( {0} );\n'.format(required_output[0])
result += '}\n' result += '}'
return result return result
preamble = """// {0} for vips operations def generate_operators(declarations_only=False):
// {1}
// this file is generated automatically, do not edit!
"""
now = datetime.datetime.now().strftime('%a %d %b %H:%M:%S %Y')
def generate_operators(filename, declarations_only=False):
all_nicknames = [] all_nicknames = []
def add_nickname(gtype, a, b): def add_nickname(gtype, a, b):
@ -235,23 +240,24 @@ def generate_operators(filename, declarations_only=False):
type_map(type_from_name('VipsOperation'), add_nickname) type_map(type_from_name('VipsOperation'), add_nickname)
# TODO: Should we add the 'missing' extract_area synonym by hand? # add 'missing' synonyms by hand
# all_nicknames.append('crop') all_nicknames.append('crop')
# make list unique and sort # make list unique and sort
all_nicknames = list(set(all_nicknames)) all_nicknames = list(set(all_nicknames))
all_nicknames.sort() all_nicknames.sort()
print('Generating {0} ...'.format(filename)) for nickname in all_nicknames:
print(generate_operation(nickname, declarations_only))
with open(filename, 'w') as f:
f.write(preamble.format('headers' if declarations_only else "bodies", now))
for nickname in all_nicknames:
f.write(generate_operation(nickname, declarations_only))
f.write('\n')
generate_operators('vips-operators.cpp') parser = argparse.ArgumentParser(description='C++ binding generator')
generate_operators('include/vips/vips-operators.h', True) parser.add_argument('--gen', '-g',
default='cpp',
choices=['h', 'cpp'],
help='File to generate: h (headers) or cpp (implementations) (default: %(default)s)')
if __name__ == '__main__':
args = parser.parse_args()
generate_operators(args.gen == 'h')

View File

@ -10,8 +10,7 @@ vips-operators.h:
echo -n "// " >> vips-operators.h; \ echo -n "// " >> vips-operators.h; \
date >> vips-operators.h; \ date >> vips-operators.h; \
echo "// this file is generated automatically, do not edit!" >> vips-operators.h; \ echo "// this file is generated automatically, do not edit!" >> vips-operators.h; \
echo "" >> vips-operators.h; \ ./../../gen-operators.py -g h >> vips-operators.h
./gen-operators-h.py >> vips-operators.h
EXTRA_DIST = \ EXTRA_DIST = \
gen-operators-h.py gen-operators-h.py

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff