diff options
Diffstat (limited to 'debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts')
29 files changed, 0 insertions, 5462 deletions
diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Gcov_test.sh b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Gcov_test.sh deleted file mode 100755 index a3853773..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Gcov_test.sh +++ /dev/null @@ -1,162 +0,0 @@ -#!/bin/bash -# -# @author Guy Maurel -# @license GPL v2+ -# -# 30. 4. 2018 -# -# The script prepare a new version of uncrustify with the compile options: -# CMAKE_CXX_FLAGS -fprofile-arcs -ftest-coverage -# CMAKE_C_FLAGS -fprofile-arcs -ftest-coverage -# to use the facilities from gcov. -# Running uncrustify with all the test data will mark all parts of the sources -# which are used. -# The "not marked" portions, if any, should give the opportunity to prepare new -# test data to complete the whole tests. -# The results are stored in the directory ${TOTALS_DIR} -# The name of the file is ${source_file}.total -# The line(s) of code which are still not used by any of the tests cases are -# marked which the token "#####" at the beginning of the line. -# As the testing part (unc_tools.cpp, backup.cpp) are only used by a developper, -# all the lines are marked. -# Also the detect.cpp part of uncrustify is completly marked. -# -# TAKE ATTENTION: -# =============== -# -# Running the test is long. I need about 20 minutes. -# This is about 40 times so much as the ctest. -# The disk space necessary is also very big, about 3 Gbytes -# This is about 1500 times bigger as the sources. -# -SCRIPT_NAME=$0 -#echo "SCRIPT_NAME="${SCRIPT_NAME} -BASE_NAME=`basename ${SCRIPT_NAME}` -DIR_NAME=`dirname ${SCRIPT_NAME}` -if [ ${DIR_NAME} != "." ] ; -then - echo "you must use the script at the directory <uncrustify_directory>/scripts" - exit -fi -cd .. -SOURCES_LIST_H=`ls -1 src/*.h | cut -b 5-` -SOURCES_LIST_CPP=`ls -1 src/*.cpp | cut -b 5-` -# -rm -rf gcov_test -mkdir gcov_test -# -cd gcov_test -# build a new uncrustify binary -cmake -D CMAKE_BUILD_TYPE=Release \ - -D CMAKE_C_FLAGS="-fprofile-arcs -ftest-coverage" \ - -D CMAKE_CXX_FLAGS="-fprofile-arcs -ftest-coverage" .. -make -# use uncrustify without parameter -./uncrustify -# -GCNO_LIST=`ls -1 ./CMakeFiles/uncrustify.dir/src/*.gcno` -for gcno_file in ${GCNO_LIST} -do - echo "gcno_file=${gcno_file}" - gcno_base_name=`basename ${gcno_file} .gcno` - echo ${gcno_base_name} - gcov ${gcno_file} -m -done -# -ADD_TEST_LIST="add_test_list.txt" -ADD_TEST_LIST_10="add_test_list_10.txt" -ADD_TEST_LIST_NUMBER="add_test_list_number.txt" -ADD_TEST_LIST_AWK="../scripts/add_test_list.awk" -ADD_TEST_LIST_CMD="add_test_list.sh" -# -# prepare a list of all tests -grep add_test ../build/tests/CTestTestfile.cmake > ${ADD_TEST_LIST} -cut -b 10- < ${ADD_TEST_LIST} > ${ADD_TEST_LIST_10} -cut --delimiter=" " --fields=1 < ${ADD_TEST_LIST_10} > ${ADD_TEST_LIST_NUMBER} -# -NUMBER_LIST=`cat ${ADD_TEST_LIST_NUMBER}` -# -# prepare a new script file to use uncrustify with all the tests cases -gawk --file ${ADD_TEST_LIST_AWK} \ - --assign sources_cpp="${SOURCES_LIST_CPP}" \ - --assign sources_h="${SOURCES_LIST_H}" < ${ADD_TEST_LIST} > ${ADD_TEST_LIST_CMD} -chmod +x ${ADD_TEST_LIST_CMD} -# -# ATTENTION: this takes about 10 minutes -# use the new script file ADD_TEST_LIST_CMD to build the information -./${ADD_TEST_LIST_CMD} -# -# compare, add the counts of each lines of generated gcov-tests -COMPARE_AND_ADD="../scripts/compare_the_gcov.awk" -TOTALS_DIR="Totals" -mkdir -p Totals -# -# choose -DO_IT_WITH_TEST="yes" -#DO_IT_WITH_TEST="no" -# -# and apply -if [ ${DO_IT_WITH_TEST} == "yes" ] -then - # do it with intermediate files - # to save the last file of each test - for test_number in ${NUMBER_LIST} - do - last_test_number=${test_number} - done - # - for source_file in ${SOURCES_LIST_CPP} - do - echo "source_file is ${source_file}" - I_file="blabla" - # this file doesn' exists - for test_number in ${NUMBER_LIST} - do - echo "source_file is ${source_file}: test_number=${test_number}" - H_DIR="${source_file}_Dir" - mkdir -p ${TOTALS_DIR}/${H_DIR} - TEST_FILE=${test_number}/${source_file}.gcov - if [ -s ${TEST_FILE} ] ; - then - O_file="${TOTALS_DIR}/${H_DIR}/${test_number}" - gawk --file ${COMPARE_AND_ADD} \ - --assign in_file="${I_file}" \ - --assign out_file="${O_file}" < ${TEST_FILE} - I_file=${O_file} - fi - # to brake before the end - #if [ "${test_number}" == "c-sharp_10010" ] - #if [ "${test_number}" == "c_10005" ] - #if [ "${test_number}" == "cpp_60042" ] - #then - # exit - #fi - done - # save the last file of each test - cp ${O_file} ${TOTALS_DIR}/${source_file}.total - done -else - # do it directly, without intermediate files - for source_file in ${SOURCES_LIST_CPP} - do - for test_number in ${NUMBER_LIST} - do - echo "source_file is ${source_file}: test_number=${test_number}" - TEST_FILE=${test_number}/${source_file}.gcov - TOTALS_FILE=${source_file} - if [ -s ${TEST_FILE} ] ; - then - gawk --file ${COMPARE_AND_ADD} \ - --assign in_file="${TOTALS_DIR}/${TOTALS_FILE}" \ - --assign out_file="${TOTALS_DIR}/${TOTALS_FILE}" < ${TEST_FILE} - fi - # to brake before the end - #if [ "${test_number}" == "c-sharp_10010" ] - #if [ "${test_number}" == "c_10005" ] - #if [ "${test_number}" == "cpp_60042" ] - #then - # exit - #fi - done - done -fi diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Run_clang-tidy.sh b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Run_clang-tidy.sh deleted file mode 100755 index c2f1c150..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/Run_clang-tidy.sh +++ /dev/null @@ -1,214 +0,0 @@ -#!/bin/bash -# -# 2017-02-27 -# -script_dir="$(dirname "$(readlink -f "$0")")" -# -SRC="${script_dir}/../src" -BUILD="${script_dir}/../build" -# -where=`pwd` -# -# build the lists -cd ${SRC} -list_of_C=`ls *.cpp` -list_of_H=`ls *.h` -list_of_files="${list_of_C} ${list_of_H}" -cd ${where} -# -RESULTS="${script_dir}/../results" -# -rm -rf ${RESULTS} -mkdir ${RESULTS} -# -COMPILE_COMMANDS="compile_commands.json" -cp ${BUILD}/${COMPILE_COMMANDS} ${SRC} -# -# choise one of list of checks -list_of_Check="\ - boost-use-to-string\ - cert-dcl21-cpp\ - cert-dcl50-cpp\ - cert-dcl58-cpp\ - cert-env33-c\ - cert-err34-c\ - cert-err52-cpp\ - cert-err58-cpp\ - cert-err60-cpp\ - cert-flp30-c\ - cert-msc50-cpp\ - cppcoreguidelines-interfaces-global-init\ - cppcoreguidelines-no-malloc\ - cppcoreguidelines-pro-bounds-array-to-pointer-decay\ - cppcoreguidelines-pro-bounds-constant-array-index\ - cppcoreguidelines-pro-bounds-pointer-arithmetic\ - cppcoreguidelines-pro-type-const-cast\ - cppcoreguidelines-pro-type-cstyle-cast\ - cppcoreguidelines-pro-type-member-init\ - cppcoreguidelines-pro-type-reinterpret-cast\ - cppcoreguidelines-pro-type-static-cast-downcast\ - cppcoreguidelines-pro-type-union-access\ - cppcoreguidelines-pro-type-vararg\ - cppcoreguidelines-slicing\ - cppcoreguidelines-special-member-functions\ - google-build-explicit-make-pair\ - google-build-namespaces\ - google-build-using-namespace\ - google-default-arguments\ - google-explicit-constructor\ - google-global-names-in-headers\ - google-readability-casting\ - google-readability-todo\ - google-runtime-int\ - google-runtime-member-string-references\ - google-runtime-memset\ - google-runtime-operator\ - google-runtime-references\ - hicpp-explicit-conversions\ - hicpp-function-size\ - hicpp-invalid-access-moved\ - hicpp-member-init\ - hicpp-named-parameter\ - hicpp-new-delete-operators\ - hicpp-no-assembler\ - hicpp-noexcept-move\ - hicpp-special-member-functions\ - hicpp-undelegated-constructor\ - hicpp-use-equals-default\ - hicpp-use-equals-delete\ - hicpp-use-override\ - llvm-header-guard\ - llvm-include-order\ - llvm-namespace-comment\ - llvm-twine-local" -#list_of_Check="misc-argument-comment\ -# misc-assert-side-effect\ -# misc-bool-pointer-implicit-conversion\ -# misc-dangling-handle\ -# misc-definitions-in-headers\ -# misc-fold-init-type\ -# misc-forward-declaration-namespace\ -# misc-forwarding-reference-overload\ -# misc-inaccurate-erase\ -# misc-incorrect-roundings\ -# misc-inefficient-algorithm\ -# misc-macro-parentheses\ -# misc-macro-repeated-side-effects\ -# misc-misplaced-const\ -# misc-misplaced-widening-cast\ -# misc-move-const-arg\ -# misc-move-constructor-init\ -# misc-move-forwarding-reference\ -# misc-multiple-statement-macro\ -# misc-new-delete-overloads\ -# misc-noexcept-move-constructor\ -# misc-non-copyable-objects\ -# misc-redundant-expression\ -# misc-sizeof-container\ -# misc-sizeof-expression\ -# misc-static-assert\ -# misc-string-compare\ -# misc-string-constructor\ -# misc-string-integer-assignment\ -# misc-string-literal-with-embedded-nul\ -# misc-suspicious-enum-usage\ -# misc-suspicious-missing-comma\ -# misc-suspicious-semicolon\ -# misc-suspicious-string-compare\ -# misc-swapped-arguments\ -# misc-throw-by-value-catch-by-reference\ -# misc-unconventional-assign-operator\ -# misc-undelegated-constructor\ -# misc-uniqueptr-reset-release\ -# misc-unused-alias-decls\ -# misc-unused-parameters\ -# misc-unused-raii\ -# misc-unused-using-decls\ -# misc-use-after-move\ -# misc-virtual-near-miss" -#list_of_Check="modernize-avoid-bind\ -# modernize-deprecated-headers\ -# modernize-loop-convert\ -# modernize-make-shared\ -# modernize-make-unique\ -# modernize-pass-by-value\ -# modernize-raw-string-literal\ -# modernize-redundant-void-arg\ -# modernize-replace-auto-ptr\ -# modernize-replace-random-shuffle\ -# modernize-return-braced-init-list\ -# modernize-shrink-to-fit\ -# modernize-use-auto\ -# modernize-use-bool-literals\ -# modernize-use-default-member-init\ -# modernize-use-emplace\ -# modernize-use-equals-default\ -# modernize-use-equals-delete\ -# modernize-use-nullptr\ -# modernize-use-override\ -# modernize-use-transparent-functors\ -# modernize-use-using\ -# mpi-buffer-deref\ -# mpi-type-mismatch\ -# performance-faster-string-find\ -# performance-for-range-copy\ -# performance-implicit-cast-in-loop\ -# performance-inefficient-string-concatenation\ -# performance-inefficient-vector-operation\ -# performance-type-promotion-in-math-fn\ -# performance-unnecessary-copy-initialization\ -# performance-unnecessary-value-param" -#list_of_Check="readability-avoid-const-params-in-decls\ -# readability-braces-around-statements\ -# readability-container-size-empty\ -# readability-delete-null-pointer\ -# readability-deleted-default\ -# readability-else-after-return\ -# readability-function-size\ -# readability-identifier-naming\ -# readability-implicit-bool-cast\ -# readability-inconsistent-declaration-parameter-name\ -# readability-misleading-indentation\ -# readability-misplaced-array-index\ -# readability-named-parameter\ -# readability-non-const-parameter\ -# readability-redundant-control-flow\ -# readability-redundant-declaration\ -# readability-redundant-function-ptr-dereference\ -# readability-redundant-member-init\ -# readability-redundant-smartptr-get\ -# readability-redundant-string-cstr\ -# readability-redundant-string-init\ -# readability-simplify-boolean-expr\ -# readability-static-definition-in-anonymous-namespace\ -# readability-uniqueptr-delete-release" -# -for file in ${list_of_files} -do - echo "test for "${file} - OUTPUT="${RESULTS}/${file}.txt" - for check in ${list_of_Check} - do - echo " test for "${check} - clang-tidy -checks="-*, ${check}" -header-filter="./${SRC}/*" ${SRC}/${file} \ - > ${OUTPUT} 2>/dev/null - if [[ -s ${OUTPUT} ]] - then - head ${OUTPUT} - break - else - rm -f ${OUTPUT} - fi - done -done -# -rm ${SRC}/${COMPILE_COMMANDS} -rmdir --ignore-fail-on-non-empty ${RESULTS} -if [[ -d ${RESULTS} ]] -then - echo "some problem(s) are still present" - exit 1 -else - echo "all clang-tidy are OK" - exit 0 -fi diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/add_test_list.awk b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/add_test_list.awk deleted file mode 100644 index 1fbe2840..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/add_test_list.awk +++ /dev/null @@ -1,56 +0,0 @@ -BEGIN { - Test_Count = 0; - count_cpp = split(sources_cpp, source_list_cpp, " "); - printf("#count_cpp= %d\n", count_cpp); - count_h = split(sources_h, source_list_h, " "); - printf("#count_h= %d\n", count_h); -} -{ - theLine = $0; - command = substr(theLine, 10); - split(command, parts, " "); - number = parts[1]; - lang = substr(parts[4], 14); - l_lang = length(lang); - lang_2 = substr(lang, 1, l_lang - 1); - config = substr(parts[5], 16); - input_file = substr(parts[7], 15); - - printf("echo \"Run uncrustify: The TESTNUMBER is %s\"\n", number); - printf("rm -rf %s\n", number); - printf("mkdir %s\n", number); - printf("cd %s\n", number); - printf("mkdir save\n"); - printf("../uncrustify -q -c \"../../tests/%s -f \"../../tests/%s -l %s -o /dev/null\n", - config, input_file, lang_2); - for (i = 1; i <= count_cpp; i++) { - source_file = source_list_cpp[i]; - function_file = sprintf("../CMakeFiles/uncrustify.dir/src/%s.gcno", source_file); - printf("if [ -s %s ] ;\n", function_file); - printf("then\n"); - printf(" gcov %s 2> /dev/null 1> /dev/null\n", function_file, source_file); - printf("fi\n"); - printf("if [ -s %s.* ] ;\n", source_file); - printf("then\n"); - printf(" mv -f %s.* ./save/\n", source_file); - printf("fi\n"); - } - for (i = 1; i <= count_h; i++) { - source_file = source_list_h[i]; - printf("if [ -s %s.* ] ;\n", source_file); - printf("then\n"); - printf(" mv -f %s.* ./save/\n", source_file); - printf("fi\n"); - } - printf(" rm *.gcov\n"); - printf(" mv save/* .\n"); - printf("rmdir save\n"); - printf("cd ..\n\n"); - # to brake before the end - #Test_Count = Test_Count + 1; - #if ( Test_Count == 1000) { - #if ( Test_Count == 109) { - #if ( Test_Count == 2) { - # printf("exit\n"); - #} -} diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/check_options.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/check_options.py deleted file mode 100644 index 1d32224b..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/check_options.py +++ /dev/null @@ -1,80 +0,0 @@ -#! /usr/bin/env python -# -# Check the option usage. -# Make sure the union member matches the option type. -# -from os.path import dirname, join, abspath -from os import listdir, EX_OK, EX_DATAERR -from fnmatch import filter - -# just use the first letter of the member name - should be unique -map_access_type = { - 'b': 'AT_BOOL', - 'a': 'AT_IARF', - 'n': 'AT_NUM', - 'u': 'AT_UNUM', - 'l': 'AT_LINE', - 't': 'AT_POS', -} -map_option_type = {} - - -# checks if while accessing the cpd.settings the right union accessor is used in the file -def check_file(file_path): - problems = 0 - line_no = 0 - - fd = open(file_path, 'r') - for line in fd: - line_no += 1 - - pos_cpd_s = line.find('cpd.settings[UO_') - pos_cpd_e = line[pos_cpd_s:].find(']') - if pos_cpd_s > 0 and pos_cpd_e > 0: - pos_option_s = pos_cpd_s + 13 - pos_option_e = pos_cpd_s + pos_cpd_e - - option = line[pos_option_s : pos_option_e] - union_access = line[pos_option_e + 2] - - if option in map_option_type and union_access in map_access_type: - if map_option_type[option] != map_access_type[union_access]: - print("%s [%d] %s should use %s not %s" % (file_path, line_no, option, - map_option_type[option], map_access_type[union_access])) - problems += 1 - return problems - - -def fill_map_option_type(file_path): - # Read in all the options - fd = open(file_path, 'r') - for line in fd: - if line.find('unc_add_option') > 0 and line.find('UO_') > 0: - splits = line.split(',') - if len(splits) >= 3: - map_option_type[splits[1].strip()] = splits[2].strip() - fd.close() - - -def main(): - src_dir = join(dirname(dirname(abspath(__file__))), 'src') - fill_map_option_type(join(src_dir, 'options.cpp')) - - # Get a list of all the source files - ld = listdir(src_dir) - src_files = filter(ld, '*.cpp') - src_files.extend(filter(ld, '*.h')) - - # Check each source file - problems = 0 - for fn in src_files: - problems += check_file(join(src_dir, fn)) - if problems == 0: - print("No problems found") - return EX_OK - else: - return EX_DATAERR - -if __name__ == '__main__': - exit(main()) - diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/cmpcfg.pl b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/cmpcfg.pl deleted file mode 100755 index df119dc1..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/cmpcfg.pl +++ /dev/null @@ -1,101 +0,0 @@ -#!/usr/bin/perl -# -# Copyright (c) 2006 David Thompson -# da.thompson@yahoo.com -# Fri Nov 17 20:41:23 PST 2006 -# License: GPL - -# Purpose of this script is to process config files and -# produce a comparision chart of values. The input files -# are simple series of parameter definitions, of the form -# 'name=value' pairs, whitespace and comments are correctly -# ignored. Invoke on multiple config files to compare -# parameter values for all files, try this, -# cd /usr/local/share/uncrustify -# cmpcfg.pl *.cfg - -# first build hashes from all input files -# 1. %name is a master hash of all parameter names found -# across all files, we use a hash to remember the keys, -# we don't compare about the values stored for each key -# 2. %table is a per file 2 dimensional hash array indexed -# by the current filename and parameter; ie, this hash -# stores the 'name=value' pairs on per file basis -foreach my $file (@ARGV) { - open FH, "<$file" - or die "Can't open file: $file"; - while (<FH>) { - chomp; - next if (/^[ \t]*$/); # ignore blank lines - next if (/^[ \t]*#/); # ignore comment lines - s/#.*$//; # strip trailing comments - s/^[ \t]*//; # strip leading whitespace - s/[ \t]*$//; # strip trailing whitespace - s/[ \t]*=[ \t]*/=/; # remove whitespace around '=' - $_ = lc; # lowercase everything - ($name, $value) = split /=/; # extract name and value - $names{$name} = $name; # master hash of all names - $table{$file}{$name} = $value; # per file hash of names - } - close FH; -} - -# find longest parameter name -# we'll use this later for report printing -foreach $name (sort keys %names) { - if (length($name) > $maxlen) { - $maxlen = length($name); - } -} -$maxlen += 4; # add extra padding - -# return string centered in specified width -sub center { - ($wid, $str) = @_; - $flg = 0; - while (length($str) < $wid) { - if ($flg) { - $flg = 0; - $str = " " . $str; - } else { - $flg = 1; - $str = $str . " "; - } - } - return $str; -} - -# print legend for filenames -$cnt = 0; -foreach $file (@ARGV) { - $cnt++; - print " <$cnt> $file\n"; -} - -# blank line separates legend & header -print "\n"; - -# print header line -print " " x $maxlen . " "; -$cnt = 0; -foreach (@ARGV) { - $cnt++; - $fmt = "<$cnt>"; - print " ".¢er(6, $fmt); -} -print "\n"; - -# print body of report, one line per parameter name -foreach $name (sort keys %names) { - printf "%-*s ", $maxlen, $name; - foreach $file (@ARGV) { - if (defined($table{$file}{$name})) { - print " ".¢er(6, $table{$file}{$name}); - } else { - # parameter not defined for this file - print " ".¢er(6, "*"); - } - } - print "\n"; -} - diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/compare_the_gcov.awk b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/compare_the_gcov.awk deleted file mode 100644 index 30dba1ad..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/compare_the_gcov.awk +++ /dev/null @@ -1,136 +0,0 @@ -BEGIN { - number_of_lines = 0; - number_of_header = 0; - T_number_of_lines = 0; - T_number_of_header = 0; - input_file = in_file; - output_file = out_file; - # - # get the first line, if any. - getline aaa <input_file; - if (ERRNO != "") { - #printf("ERRNO is %s\n", ERRNO); - #printf("a new file will be created at %s\n", output_file); - # totals-file not found, this is the first run. - first_run = "yes"; - } else { - # totals-file is found. Read it into the arrays - first_run = "no"; - for ( i = 1; i < 20000; i++) { - theLine = aaa; - where_is_colon_1 = index(theLine, ":"); - part_1 = substr(theLine, 1, where_is_colon_1 - 1); - rest_1 = substr(theLine, where_is_colon_1 + 1); - where_is_colon_2 = index(rest_1, ":"); - part_2 = substr(rest_1, 1, where_is_colon_2 - 1) + 0; - rest_2 = substr(rest_1, where_is_colon_2 + 1); - if (part_2 == 0) { - # header part - T_number_of_header = T_number_of_header + 1; - T_header_part1[T_number_of_header] = part_1; - T_header_part2[T_number_of_header] = part_2; - T_header_part3[T_number_of_header] = rest_2; - } else { - # source lines - # a new line - T_number_of_lines = part_2; - T_source_part1[T_number_of_lines] = part_1; - T_source_part2[T_number_of_lines] = part_2; - T_source_part3[T_number_of_lines] = rest_2; - } - - aaa = ""; - # get the next line - getline aaa <input_file; - if (aaa == "") { - # EOF - break; - } - } - close(input_file); - # Test it - #printf("Test it\n"); - #for (i = 1; i <= T_number_of_header; i++) { - # printf("%8s:%5d:%s\n", T_header_part1[i], T_header_part2[i], T_header_part3[i]); - #} - #for (i = 1; i <= T_number_of_lines; i++) { - # printf("%8s:%5d:%s\n", T_source_part1[i], T_source_part2[i], T_source_part3[i]); - #} - } -} - -{ - theLine = $0; - where_is_colon_1 = index(theLine, ":"); - part_1 = substr(theLine, 1, where_is_colon_1 - 1); - rest_1 = substr(theLine, where_is_colon_1 + 1); - where_is_colon_2 = index(rest_1, ":"); - part_2 = substr(rest_1, 1, where_is_colon_2 - 1) + 0; - rest_2 = substr(rest_1, where_is_colon_2 + 1); - if (part_2 == 0) { - # header part - number_of_header = number_of_header + 1; - header_part1[number_of_header] = part_1; - header_part2[number_of_header] = part_2; - header_part3[number_of_header] = rest_2; - } else { - # source lines - # a new line - number_of_lines = part_2; - source_part1[number_of_lines] = part_1; - source_part2[number_of_lines] = part_2; - source_part3[number_of_lines] = rest_2; - where_ = index(part_1, "-"); - if (where_ > 0) { - # don't take care - } else { - where_2 = index(part_1, "#####"); - if (where_2 > 0) { - # don't take care - } else { - d_part_1 = part_1 + 0; - # look at T_source_part1[part_2] - where_3 = index(T_source_part1[part_2], "#####"); - if (where_3 > 0) { - sum = d_part_1; - # write the sum to T_source_part1 - T_source_part1[part_2] = d_part_1; - } else { - d_T = T_source_part1[part_2] + 0; - sum = d_part_1 + d_T; - # write the sum back to T_source_part1 - T_source_part1[part_2] = sum; - } - } - } - } -} -END { - if (first_run == "yes") { - # copy to T_ - T_number_of_header = number_of_header; - T_number_of_lines = number_of_lines; - for(i = 1; i <= T_number_of_header; i++) { - T_header_part1[i] = header_part1[i]; - T_header_part2[i] = header_part2[i]; - T_header_part3[i] = header_part3[i]; - } - for (i = 1; i <= T_number_of_lines; i++) { - T_source_part1[i] = source_part1[i]; - T_source_part2[i] = source_part2[i]; - T_source_part3[i] = source_part3[i]; - } - } - #printf("T_number_of_header is %d\n", T_number_of_header); - #printf("T_number_of_lines is %d\n", T_number_of_lines); - - # delete the previous version - printf("") > output_file; - for(i = 1; i <= T_number_of_header; i++) { - printf("%9s:%5d:%s\n", T_header_part1[i], T_header_part2[i], T_header_part3[i]) >> output_file; - } - for (i = 1; i <= T_number_of_lines; i++) { - printf("%9s:%5d:%s\n", T_source_part1[i], T_source_part2[i], T_source_part3[i]) >> output_file; - } - close(output_file); -} diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_changelog.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_changelog.py deleted file mode 100755 index 8e042385..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_changelog.py +++ /dev/null @@ -1,111 +0,0 @@ -#!/usr/bin/env python - -''' -This script attempts to extract what options have been added since the -specified revision (usually a tag, but any revision that git recognizes may be -provided). It accepts an optional second revision to use as the cut-off. The -default is your LOCAL "master". Thus, you should ensure that this is up to date -before running this script. - -This script works by extracting the set of options before and after every -commit that affected ':src/options.h' and computing the differences. It should, -therefore, be fairly robust (for example, options that moved around won't show -up). However, if an option is removed and subsequently re-added, or if an -option was added and subsequently removed, the resulting records will need to -be reconciled manually. -''' - -import argparse -import git -import os -import re -import sys -import time - -re_option = re.compile(r'extern (Bounded)?Option<[^>]+>') - - -# ----------------------------------------------------------------------------- -def extract_options(repo, blob_id): - from git.util import hex_to_bin - - blob = git.Blob(repo, hex_to_bin(blob_id)) - content = blob.data_stream.stream - options = set() - - for line in iter(content.readline, b''): - line = line.decode('utf-8').strip() - - if re_option.match(line): - line = content.readline().decode('utf-8').strip() - options.add(line.split(';')[0]) - - return options - - -# ============================================================================= -class Changeset(object): - # ------------------------------------------------------------------------- - def __init__(self, repo, sha): - self.sha = sha - self.added_options = set() - self.removed_options = set() - - commit = repo.commit(sha) - ad = time.gmtime(commit.authored_date) - self.date = time.strftime('%b %d %Y', ad).replace(' 0', ' ') - - info = repo.git.log('-1', '--raw', '--abbrev=40', '--pretty=', - sha, '--', ':src/options.h').split(' ') - if len(info) < 5: - return - - old_options = extract_options(repo, info[2]) - new_options = extract_options(repo, info[3]) - self.added_options = new_options.difference(old_options) - self.removed_options = old_options.difference(new_options) - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser( - description='Generate changelog for new options') - - root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..')) - parser.add_argument('--repo', type=str, default=root, - help='Path to uncrustify git repository') - parser.add_argument('since', type=str, - help='Revision (tag) of previous uncrustify version') - parser.add_argument('until', type=str, default='master', nargs='?', - help='Revision (tag) of next uncrustify version') - - args = parser.parse_args() - repo = git.Repo(args.repo) - revs = repo.git.log('--pretty=%H', '--reverse', - '{}..{}'.format(args.since, args.until), - '--', ':src/options.h').split('\n') - - if revs == ['']: - print('No changes were found') - return 1 - - changes = [] - for r in revs: - c = Changeset(repo, r) - if len(c.added_options) or len(c.removed_options): - changes.append(c) - - for c in changes: - print(c.sha) - for o in c.added_options: - print(' Added : {:36} {}'.format(o, c.date)) - for o in c.removed_options: - print(' Removed : {:36} {}'.format(o, c.date)) - - return 0 - - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -if __name__ == '__main__': - sys.exit(main()) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output.py deleted file mode 100644 index 2fa4fb0c..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output.py +++ /dev/null @@ -1,493 +0,0 @@ -from __future__ import print_function # python >= 2.6 -from os import makedirs, path, listdir, rename, remove -from subprocess import Popen -from filecmp import cmp -from glob import iglob -from shutil import rmtree -from json import loads as json_loads, dump as json_dump -from sys import stderr, argv, path as sys_path - -""" -gen_config_combinations_uniq_output.py - -Creates from a given set of options all possible option settings -combinations, formats files with those and displays how much non equal -formatted outputs have been created. - -Expects arg1 to be a filepath to a json config file - (see config example below) - -:author: Daniel Chumak -:license: GPL v2+ -""" - - -# config = { -# "option_settings": { -# "AT_BOOL": ["False", "True"], -# "AT_IARF": ["ignore", "add", "remove", "force"], -# "AT_POS": ["ignore", "join", "lead", "lead_break", "lead_force", -# "trail", "trail_break", "trail_force"], -# "AT_LINE": ["auto", "lf", "crlf", "cr"], -# "AT_NUM": [-2, -1, 0, 1, 2, 3], -# "AT_UNUM": [0, 1, 2, 3] -# }, -# "options": [{ -# "name": "nl_func_type_name", -# "type": "AT_IARF" -# }, { -# "name": "nl_template_class", -# "type": "AT_IARF" -# }], -# "out_dir": "./Out", -# "in_files": ["./t.cpp", "./t2.cpp"], -# "unc_bin": "../build/uncrustify", -# "cleanup_lvl": 2, -# "force_cleanup": false, -# "json_output": false -# } -# - - -def len_index_combinations(max_indices): - """generator function that yields a list starting from - n_0 = 0, ... n_m-1 = 0, n_m = 0 - ... - n_0 = 0, ... n_m-1 = 0, n_m = n_m_max - ... - n_0 = 0, ... n_m-1 = 1, n_m = 0 - n_0 = 0, ... n_m-1 = 1, n_m = 1 - ... - n_0 = 0, ... n_m-1 = n_m-1_max, n_m = n_m_max - ... - n_0 = n_0_max, ... n_m-1 = n_m-1_max, n_m = n_m_max - - - :param max_indices: list of max values every position is going to reach - - :yield: list of values at the current step - """ - - fields = len(max_indices) - accu = [0] * fields - - # increment last position n, on max val move pos by one (n-1) and increment - # if (n-1) is max move again (n-2) and increment, ... - pos = fields - while pos >= 0: - yield (accu) - - pos = fields - 1 - accu[pos] += 1 - - # on reaching max reset value, move pos and increment at pos - while pos >= 0 and accu[pos] >= max_indices[pos]: - accu[pos] = 0 - pos -= 1 - - if pos >= 0: - accu[pos] += 1 - - -def write_config_files(config): - """Writes a configuration file for each possible combination of 'option' - settings - - :param config: configuration object, expects that it was processed by - check_config - """ - - options_len = len(config["options"]) - - # populate len_options with amount of settings for the types of each option - len_options = [0] * options_len - for i in range(options_len): - option_setting = config["options"][i]["type"] - len_options[i] = len(config["option_settings"][option_setting]) - - # write configuration files, one per possible combination - for combination in len_index_combinations(len_options): - len_indices = len(combination) - - # generate output filepath - file_path = config['out_dir'] + "/" - for i in range(len_indices): - option_name = config["options"][i]["name"] - file_path += ("%s__" % option_name) - for i in range(len_indices): - option_type = config["options"][i]["type"] - option_setting = combination[i] - file_path += ("%d__" % option_setting) - file_path += "unc.cfg" - - # write configuration file - with open(file_path, 'w') as f: - for i in range(len_indices): - option_name = config["options"][i]["name"] - option_type = config["options"][i]["type"] - option_setting = config["option_settings"][option_type][ - combination[i]] - - f.write("%s = %s\n" % (option_name, option_setting)) - - -def gen_equal_output_map(config): - """Formats 'in_files' with configs inside the 'out_dir' with Uncrustify and - groups formatted files with equal content together. - Expects config filename format generated by write_config_files - - :param config: configuration object, expects that it was processed by - check_config - :return: dict of files with equal content - key -- group index - value -- filepath list - """ - - # maps that will hold configurations that produce the same formatted files - equal_output_map = {} - # map len counter - map_val_idx = 0 - - # iterate through all generated config file names - - for cfg_path in sorted(iglob('%s/*.cfg' % config["out_dir"])): - for in_file_idx in range(len(config["in_files"])): - # extract substring form config gile name (removes __unc.cfg) - splits_file = cfg_path.split("__unc") - if len(splits_file) < 1: - raise Exception('split with "__unc" | Wrong split len: %d' - % len(splits_file)) - - out_path = ("%s__%d" % (splits_file[0], in_file_idx)) - - # gen formatted files with uncrustify binary - proc = Popen([config["unc_bin"], - "-c", cfg_path, - "-f", config["in_files"][in_file_idx], - "-o", out_path, - ]) - proc.wait() - if proc.returncode != 0: - continue - - # populate 'equal_output_map' map - if len(equal_output_map) == 0: - equal_output_map[0] = [out_path] - map_val_idx += 1 - else: - found_flag = False - for i in range(map_val_idx): - # compare first file of group i with the generated file - if cmp(equal_output_map[i][0], out_path): - equal_output_map[i].append(out_path) - found_flag = True - break - # create new group if files do not match - if not found_flag: - equal_output_map[map_val_idx] = [out_path] - map_val_idx += 1 - - return equal_output_map - - -def gen_output_dict(config, equal_output_map): - """Makes an output dict with the generated results. - - :param config: configuration object, expects that it was processed by - check_config - - :param equal_output_map: dict of files with equal content, - expects format generated by gen_equal_output_map - :return: output dict, format: - copies objects option_settings, options and in_files (renamed as - files) from the config object. Additionally has the object groups - that holds gourp - file - settings combination data - format: - groups = [ [fileIdx0[ - [settingIdx0, settingIdx1, ...], - [settingIdx0, settingIdx1, ...] ] ] - [fileIdx1[ - [settingIdx0, settingIdx1, ...], - [settingIdx0, settingIdx1, ...] ] ] - ] - """ - - output_dict = {"option_settings": config["option_settings"], - "options": config["options"], - "files": config["in_files"], - "groups": []} - - options_len = len(output_dict["options"]) - files_len = len(output_dict["files"]) - - for key in equal_output_map: - group_dict = [] - for file_arr_idx in range(files_len): - group_dict.append([]) - - for list_value in equal_output_map[key]: - split = list_value.rsplit("/", 1) - split = split[len(split) - 1].split("__") - split_len = len(split) - - # n option names + n option values + file idx - if split_len < options_len * 2 + 1: - print(" wrong split len on %s\n" % list_value, file=stderr) - continue - - file_idx = int(split[split_len - 1]) - file_combinations = [int(i) for i in split[options_len:split_len-1]] - - group_dict[file_idx].append(file_combinations) - - output_dict["groups"].append(group_dict) - - return output_dict - - -def write_output_dict_pretty(out_dict, out_path): - """pretty prints the output dict into a file - - :param out_dict: dict that will be printed, expects format generated by - gen_output_dict - - :param out_path: output filepath - """ - - group_id = 0 - options_len = len(out_dict["options"]) - - with open(out_path, 'w') as f: - - f.write("Files:\n") - for in_file_idx in range(len(out_dict["files"])): - f.write(" %d: %s\n" % (in_file_idx, - out_dict["files"][in_file_idx])) - - f.write("\nOptions:\n") - for option_idx in range(options_len): - f.write(" %d: %s\n" % (option_idx, - out_dict["options"][option_idx]["name"])) - f.write("\n\n") - - for group in out_dict["groups"]: - f.write("Group: %d\n" % group_id) - group_id += 1 - - for file_idx in range(len(group)): - file = group[file_idx] - - for combinations in file: - combination_strings = [] - for combination_idx in range(len(combinations)): - - combination_id = combinations[combination_idx] - combination_string = out_dict["option_settings"][ - out_dict["options"][combination_idx]["type"]][ - combination_id] - combination_strings.append(str(combination_string)) - f.write(" (%s: %s)\n" % (file_idx, - " - ".join(combination_strings))) - f.write("\n") - - -def load_config(file_path): - """reads a file and parses it as json - - :param file_path: path to the json file - - :return: json object - """ - - with open(file_path, 'r') as f: - string = f.read() - json = json_loads(string) - - return json - - -def make_abs_path(basis_abs_path, rel_path): - return path.normpath(path.join(basis_abs_path, rel_path)) - - -def check_config(config, cfg_path=""): - """checks if the provided config has all needed options, sets default - settings for optional options and transform relative paths into absolute - paths. - - :param config: config dict that will be checked - - :param cfg_path: if not empty transforms relative to absolute paths, - paths will be based upon the cfg_path. - """ - - extend_relative_paths = True if len(cfg_path) > 0 else False - cfg_path = path.abspath(path.dirname(cfg_path)) - - # -------------------------------------------------------------------------- - - if "option_settings" not in config: - raise Exception("config file: 'option_settings' missing") - - if len(config["option_settings"]) == 0: - raise Exception("config file: 'option_settings' values missing") - - # -------------------------------------------------------------------------- - - if "options" not in config: - raise Exception("config file: 'options' missing") - - if len(config["options"]) < 2: - raise Exception("config file: 'options' min. two options needed") - - for option_obj in config["options"]: - if "name" not in option_obj: - raise Exception("config file: 'options[{}]' name missing") - if "type" not in option_obj: - raise Exception("config file: 'options[{}]' type missing") - if option_obj["type"] not in config["option_settings"]: - raise Exception("config file: 'options[{type='%s'}]' not in option_" - "settings" % option_obj["type"]) - - # -------------------------------------------------------------------------- - - if "out_dir" not in config: - raise Exception("config file: 'out_dir' missing") - - if len(config['out_dir']) == 0: - raise Exception("config file: 'out_dir' value missing") - - if extend_relative_paths and not path.isabs(config['out_dir']): - config['out_dir'] = make_abs_path(cfg_path, config['out_dir']) - - # -------------------------------------------------------------------------- - - if "in_files" not in config: - raise Exception("config file: 'in_files' missing") - - if len(config['in_files']) == 0: - raise Exception("config file: 'in_files' values missing") - - for file_idx in range(len(config['in_files'])): - if extend_relative_paths and not path.isabs( - config['in_files'][file_idx]): - config['in_files'][file_idx] = make_abs_path(cfg_path, - config['in_files'][ - file_idx]) - - if not path.isfile(config['in_files'][file_idx]): - raise Exception("config file: '%s' is not a file" - % config['in_files'][file_idx]) - - # -------------------------------------------------------------------------- - - if "unc_bin" not in config: - raise Exception("config file: 'in_files' missing") - - if extend_relative_paths and not path.isabs(config['unc_bin']): - config['unc_bin'] = make_abs_path(cfg_path, config['unc_bin']) - - if not path.isfile(config['unc_bin']): - raise Exception("config file: '%s' is not a file" % config['unc_bin']) - - # Optional ----------------------------------------------------------------- - - if "cleanup_lvl" not in config: - config["cleanup_lvl"] = 1 - - if "force_cleanup" not in config: - config["force_cleanup"] = False - - if "json_output" not in config: - config["json_output"] = False - - -def cleanup(level, eq_map, clean_target_dir, keep_files=()): - """cleans up output_dir - - :param level: 0 - do nothing, - 1 - keep `keep_files` and 1 file for each group, - 2 - remove everything - - :param equal_output_map: dict of files with equal content, - expects format generated by gen_equal_output_map - - :param clean_target_dir: directory which content will be cleaned - - :param keep_files: list of files should not be removed - """ - - if level == 0: - return - - if level == 2: - rmtree(clean_target_dir) - - if level == 1: - rm_files = [clean_target_dir + "/" + f for f in - listdir(clean_target_dir)] - - for f in keep_files: - rm_files.remove(f) - - for idx in eq_map: - old_path = eq_map[idx][0] - new_path = ("%s/g_%d" % (path.dirname(path.abspath(old_path)), idx)) - rename(old_path, new_path) - - try: - rm_files.remove(old_path) - except ValueError: - pass # ignore that it is missing - - try: - rm_files.remove(new_path) - except ValueError: - pass # ignore that it is missing - - for f in rm_files: - remove(f) - - -def main(args): - config = load_config(args[0]) - check_config(config, args[0]) - - # gen output directory - if path.isfile(config["out_dir"]): - raise Exception("%s is a file" % config["out_dir"]) - - if not path.isdir(config["out_dir"]): - makedirs(config["out_dir"]) - elif not config["force_cleanup"] and config["cleanup_lvl"] > 0: - raise Exception("cleanup_lvl > 0 on an existing directory: %s" - % config["out_dir"]) - - write_config_files(config) - eq_map = gen_equal_output_map(config) - output_dict = gen_output_dict(config, eq_map) - - # write output as txt file - output_dict_path = path.join(config["out_dir"], "out.txt") - write_output_dict_pretty(output_dict, output_dict_path) - - # read ouput txt file to print it - with open(output_dict_path, 'r') as f: - print() - print(f.read()) - - keep_files = [output_dict_path] - - # write output as json file - if config["json_output"]: - output_dict_json_path = path.join(config["out_dir"], "out.json") - with open(output_dict_json_path, 'w') as f: - json_dump(output_dict, f) - keep_files.append(output_dict_json_path) - - # clean output directory - cleanup(config["cleanup_lvl"], eq_map, config["out_dir"], keep_files) - - -if __name__ == "__main__": - main(argv[1:]) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output_example.json b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output_example.json deleted file mode 100644 index 315fdfef..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/gen_config_combinations_uniq_output_example.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "option_settings": { - "AT_BOOL": ["False", "True"], - "AT_IARF": ["ignore", "add", "remove", "force"], - "AT_POS": ["ignore", "join", "lead", "lead_break", "lead_force", - "trail", "trail_break", "trail_force" - ], - "AT_LINE": ["auto", "lf", "crlf", "cr"], - "AT_NUM": [-2, -1, 0, 1, 2, 3], - "AT_UNUM": [0, 1, 2, 3] - }, - "options": [{ - "name": "nl_func_type_name", - "type": "AT_IARF" - }, { - "name": "nl_template_class", - "type": "AT_IARF" - }], - "out_dir": "./out_uniq_outputs", - "in_files": ["../src/uncrustify.cpp", "../src/width.h"], - "unc_bin": "../build/uncrustify", - "cleanup_lvl" : 0, - "force_cleanup": false, - "json_output": false -} diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/grammar_permutator.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/grammar_permutator.py deleted file mode 100755 index cd42bd9f..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/grammar_permutator.py +++ /dev/null @@ -1,93 +0,0 @@ -#!/usr/bin/python -import argparse - -from nltk.parse.generate import generate -from nltk import CFG -from os.path import exists -from sys import exit as sys_exit - -DEMO_GRAMMAR = """ - S -> 'import ' ImportList ';' | 'static import ' ImportList ';' - ImportList -> Import | ImportBindings | Import ', ' ImportList - Import -> ModuleFullyQualifiedName | ModuleAliasIdentifier ' = ' ModuleFullyQualifiedName - ImportBindings -> Import ' : ' ImportBindList - ImportBindList -> ImportBind | ImportBind ', ' ImportBindList - ImportBind -> Identifier | Identifier ' = ' Identifier - - ModuleAliasIdentifier -> Identifier - - Packages -> PackageName | Packages '.' PackageName - ModuleFullyQualifiedName -> ModuleName | Packages '.' ModuleName - PackageName -> Identifier - ModuleName -> Identifier - - Identifier -> 'x' -""" - - -def valid_file(arg_parser, *args): - """ - checks if on of the provided paths is a file - - - Parameters - ---------------------------------------------------------------------------- - :param arg_parser: - argument parser object that is called if no file is found - - :param args: list< str > - a list of file path that is going to be checked - - - :return: str - ---------------------------------------------------------------------------- - path to an existing file - """ - arg = None - found_flag = False - for arg in args: - if exists(arg): - found_flag = True - break - if not found_flag: - arg_parser.error("file(s) do not exist: %s" % args) - - return arg - - -def main(args): - grammar_string = DEMO_GRAMMAR - - if args.input_file_path: - with open(args.input_file_path, 'r') as f: - grammar_string = f.read() - - grammar = CFG.fromstring(grammar_string) - - for sentence in generate(grammar, depth=args.depth): - print(''.join(sentence)) - - return 0 - - -if __name__ == "__main__": - arg_parser = argparse.ArgumentParser() - - arg_parser.add_argument( - '-i', '--input_file_path', - metavar='<path>', - type=lambda x: valid_file(arg_parser, x), - help="Path to the grammar file", - required=False - ) - arg_parser.add_argument( - '-d', '--depth', - metavar='<nr>', - type=int, - default=9, - help='Max depth of grammar tree.' - ) - - FLAGS, unparsed = arg_parser.parse_known_args() - - sys_exit(main(FLAGS)) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_katehl.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_katehl.py deleted file mode 100755 index e241986a..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_katehl.py +++ /dev/null @@ -1,157 +0,0 @@ -#!/usr/bin/env python - -import argparse -import io -import os -import re - -re_token = re.compile(r'^CT_(\w+),') -re_version = re.compile(r'.*UNCRUSTIFY_VERSION\s*"Uncrustify-([^"]+)"') -re_option = re.compile(r'extern (Bounded)?Option<[^>]+>') -re_enum_decl = re.compile(r'enum class (\w+)( *// *<(\w+)>)?') -re_enum_value = re.compile(r'(\w+)(?= *([,=]|//|$))') -re_aliases = re.compile(r'UNC_OPTVAL_ALIAS\(([^)]+)\)') - -version = '0.0' -options = set() -values = set() -tokens = set() - -root = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) -script = os.path.relpath(__file__, root) - - -# ----------------------------------------------------------------------------- -def read_enum(f): - global values - - for line in iter(f.readline, ''): - line = line.strip() - - if line.startswith('{'): - for line in iter(f.readline, ''): - line = line.strip() - - if line.startswith('};'): - return - - if 'UNC_INTERNAL' in line: - return - - if 'UNC_CONVERT_INTERNAL' in line: - return - - mv = re_enum_value.match(line) - if mv is not None: - values.add(mv.group(1).lower()) - - -# ----------------------------------------------------------------------------- -def write_items(out, items): - for i in sorted(items): - out.write(u' <item>{}</item>\n'.format(i)) - - -# ----------------------------------------------------------------------------- -def write_options(out, args): - write_items(out, options) - - -# ----------------------------------------------------------------------------- -def write_values(out, args): - write_items(out, values) - - -# ----------------------------------------------------------------------------- -def write_tokens(out, args): - write_items(out, tokens) - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser(description='Generate uncrustify.xml') - parser.add_argument('output', type=str, - help='location of uncrustify.xml to write') - parser.add_argument('template', type=str, - help='location of uncrustify.xml.in ' + - 'to use as template') - parser.add_argument('version', type=str, - help='location of uncrustify_version.h to read') - parser.add_argument('options', type=str, - help='location of options.h to read') - parser.add_argument('optvals', type=str, - help='location of option.h to read') - parser.add_argument('tokens', type=str, - help='location of token_enum.h to read') - args = parser.parse_args() - - # Read version - with io.open(args.version, 'rt', encoding='utf-8') as f: - global version - for line in iter(f.readline, ''): - line = line.strip() - - mv = re_version.match(line) - if mv: - version = mv.group(1) - - # Read options - with io.open(args.options, 'rt', encoding='utf-8') as f: - global options - for line in iter(f.readline, ''): - line = line.strip() - - if re_option.match(line): - n, d = f.readline().split(';') - options.add(n) - - # Read option values - with io.open(args.optvals, 'rt', encoding='utf-8') as f: - global values - for line in iter(f.readline, ''): - line = line.strip() - - if re_enum_decl.match(line): - read_enum(f) - continue - - ma = re_aliases.match(line) - if ma: - for v in ma.group(1).split(',')[2:]: - v = v.strip()[1:-1] - values.add(v) - - # Read tokens - with io.open(args.tokens, 'rt', encoding='utf-8') as f: - global tokens - for line in iter(f.readline, ''): - line = line.strip() - - m = re_token.match(line) - if m and not m.group(1).endswith(u'_'): - tokens.add(m.group(1).lower()) - - # Declare replacements - replacements = { - u'##OPTION_KEYWORDS##': write_options, - u'##VALUE_KEYWORDS##': write_values, - u'##TOKEN_TYPE_KEYWORDS##': write_tokens, - } - - # Write output file - with io.open(args.output, 'wt', encoding='utf-8') as out: - with io.open(args.template, 'rt', encoding='utf-8') as t: - for line in t: - directive = line.strip() - if directive in replacements: - replacements[directive](out, args) - else: - if '##VERSION##' in line: - line = line.replace('##VERSION##', version) - out.write(line) - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - - -if __name__ == '__main__': - main() diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_option_enum.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_option_enum.py deleted file mode 100644 index c141bb04..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_option_enum.py +++ /dev/null @@ -1,215 +0,0 @@ -#!/usr/bin/env python - -import argparse -import io -import os -import re - -re_enum_decl = re.compile(r'enum class (\w+)( *// *<(\w+)>)?') -re_enum_value = re.compile(r'(\w+)(?= *([,=]|//|$))') -re_values = re.compile(r'UNC_OPTVALS\((\w+)\)') -re_aliases = re.compile(r'UNC_OPTVAL_ALIAS\(([^)]+)\)') -enums = {} -values = {} - -root = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) -script = os.path.relpath(__file__, root) - - -# ============================================================================= -class Enumeration(object): - # ------------------------------------------------------------------------- - def __init__(self, name, prefix, f): - self.name = name - self.prefix = prefix - - self.values = [] - self.value_aliases = {} - - self.convert_internal = False - - for line in iter(f.readline, ''): - line = line.strip() - - if line.startswith('{'): - for line in iter(f.readline, ''): - line = line.strip() - if line.startswith('};'): - return - - if 'UNC_INTERNAL' in line: - return - - if 'UNC_CONVERT_INTERNAL' in line: - self.convert_internal = True - continue - - mv = re_enum_value.match(line) - if mv is not None: - v = mv.group(1) - self.values.append(v) - self.value_aliases[v] = [v.lower()] - - # ------------------------------------------------------------------------- - def add_aliases(self, value, *args): - aliases = [x[1:-1] for x in args] # strip quotes - self.value_aliases[value] += aliases - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - - -# ----------------------------------------------------------------------------- -def enum_value(enum, value): - if enum.prefix is not None: - return u'{}_{}'.format(enum.prefix, value) - return value - -# ----------------------------------------------------------------------------- -def write_banner(out, args): - out.write( - u'/**\n' - u' * @file {out_name}\n' - u' * Helpers for option enumerators.\n' - u' * Automatically generated by <code>{script}</code>\n' - u' * from {in_name}.\n' - u' */\n' - u'\n'.format( - in_name=os.path.basename(args.header), - out_name=os.path.basename(args.output), - script=script)) - - -# ----------------------------------------------------------------------------- -def write_value_strings(out, args): - for vn, vs in values.items(): - out.write(u'const char *const {}_values[] = {{\n'.format(vn)) - out.write(u'{}\n nullptr\n}};\n\n'.format( - u'\n'.join([u' "{}",'.format(x.lower()) for x in vs]))) - - -# ----------------------------------------------------------------------------- -def write_aliases(out, args): - for enum in enums.values(): - if enum.prefix is None: - continue - - for v in enum.values: - out.write(u'constexpr auto {p}_{v} = {n}::{v};\n'.format( - p=enum.prefix, n=enum.name, v=v)) - - out.write(u'\n') - - -# ----------------------------------------------------------------------------- -def write_conversions(out, args): - header = u'\n//{}\n'.format('-' * 77) - - for enum in enums.values(): - if enum.convert_internal: - continue - - out.write(header) - out.write( - u'bool convert_string(const char *in, {} &out)\n'.format( - enum.name)) - out.write( - u'{\n' - u' if (false)\n' - u' {\n' - u' }\n') - - for v in enum.values: - for a in enum.value_aliases[v]: - out.write( - u' else if (strcasecmp(in, "{}") == 0)\n' - u' {{\n' - u' out = {};\n' - u' return(true);\n' - u' }}\n'.format(a, enum_value(enum, v))) - - out.write( - u' else\n' - u' {\n' - u' return(false);\n' - u' }\n' - u'}\n\n') - - for enum in enums.values(): - out.write(header) - out.write(u'const char *to_string({} val)\n'.format(enum.name)) - out.write(u'{\n' - u' switch (val)\n' - u' {\n') - - for v in enum.values: - vs = v if enum.convert_internal else v.lower() - out.write( - u' case {}:\n' - u' return "{}";\n\n'.format( - enum_value(enum, v), vs)) - - out.write( - u' default:\n' - u' fprintf(stderr, "%s: Unknown {} \'%d\'\\n",\n' - u' __func__, static_cast<int>(val));\n' - u' log_flush(true);\n' - u' exit(EX_SOFTWARE);\n' - u' }}\n' - u'}}\n\n'.format(enum.name)) - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser(description='Generate options.cpp') - parser.add_argument('output', type=str, - help='location of options.cpp to write') - parser.add_argument('header', type=str, - help='location of options.h to read') - parser.add_argument('template', type=str, - help='location of option_enum.cpp.in ' - 'to use as template') - args = parser.parse_args() - - with io.open(args.header, 'rt', encoding='utf-8') as f: - for line in iter(f.readline, ''): - line = line.strip() - - me = re_enum_decl.match(line) - if me is not None: - e = Enumeration(me.group(1), me.group(3), f) - enums[e.name] = e - continue - - mv = re_values.match(line) - if mv is not None: - enum_name = mv.group(1) - enum = enums['{}_e'.format(enum_name)] - values[enum_name] = enum.values - - ma = re_aliases.match(line) - if ma is not None: - alias_args = [x.strip() for x in ma.group(1).split(',')] - enum = enums[alias_args[0]] - enum.add_aliases(*alias_args[1:]) - - replacements = { - u'##BANNER##': write_banner, - u'##VALUE_STRINGS##': write_value_strings, - u'##ALIASES##': write_aliases, - u'##CONVERSIONS##': write_conversions, - } - - with io.open(args.output, 'wt', encoding='utf-8') as out: - with io.open(args.template, 'rt', encoding='utf-8') as t: - for line in t: - directive = line.strip() - if directive in replacements: - replacements[directive](out, args) - else: - out.write(line) - - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -if __name__ == '__main__': - main() diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_options.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_options.py deleted file mode 100755 index 71e97115..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_options.py +++ /dev/null @@ -1,153 +0,0 @@ -#!/usr/bin/env python - -import argparse -import io -import os -import re - -max_name_len = 60 - -re_name = re.compile(r'^[a-z][a-z0-9_]*$') -re_group = re.compile(r'//BEGIN') -re_option = re.compile(r'extern (Bounded)?Option<[^>]+>') -re_default = re.compile(r' *// *= *(.*)') -groups = [] - -root = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) -script = os.path.relpath(__file__, root) - - -# ============================================================================= -class Group(object): - # ------------------------------------------------------------------------- - def __init__(self, desc): - self.desc = desc - self.options = [] - - # ------------------------------------------------------------------------- - def append(self, option): - self.options.append(option) - - -# ============================================================================= -class Option(object): - # ------------------------------------------------------------------------- - def __init__(self, name, dval, decl, desc): - if re_name.match(name) is None: - raise ValueError('{!r} is not a valid option name'.format(name)) - if len(name) > max_name_len: - raise ValueError( - '{!r} (length={:d}) exceeds the maximum length {:d}'.format( - name, len(name), max_name_len)) - - self.desc = u'\n'.join(desc) - self.decl = decl[7:] - self.name = name - self.dval = dval - - # ------------------------------------------------------------------------- - def write_declaration(self, out): - out.write(u'{} {} = {{\n'.format(self.decl, self.name)) - out.write(u' "{}",\n'.format(self.name)) - out.write(u' u8R"__(\n{}\n)__"'.format(self.desc)) - if self.dval is not None: - out.write(u',\n {}'.format(self.dval)) - out.write(u'\n};\n\n') - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - - -# ----------------------------------------------------------------------------- -def extract_default(decl): - m = re_default.match(decl) - if m: - return m.group(1) - return None - - -# ----------------------------------------------------------------------------- -def write_banner(out, args): - out.write( - u'/**\n' - u' * @file {out_name}\n' - u' * Declaration and initializers for all options.\n' - u' * Automatically generated by <code>{script}</code>\n' - u' * from {in_name}.\n' - u' */\n' - u'\n'.format( - in_name=os.path.basename(args.header), - out_name=os.path.basename(args.output), - script=script)) - - -# ----------------------------------------------------------------------------- -def write_declarations(out, args): - for group in groups: - for option in group.options: - option.write_declaration(out) - - -# ----------------------------------------------------------------------------- -def write_registrations(out, args): - for group in groups: - out.write(u'\n begin_option_group(u8R"__(\n{}\n)__");\n\n'.format( - group.desc)) - - for option in group.options: - out.write(u' register_option(&options::{});\n'.format( - option.name)) - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser(description='Generate options.cpp') - parser.add_argument('output', type=str, - help='location of options.cpp to write') - parser.add_argument('header', type=str, - help='location of options.h to read') - parser.add_argument('template', type=str, - help='location of options.cpp.in to use as template') - args = parser.parse_args() - - with io.open(args.header, 'rt', encoding='utf-8') as f: - desc = [] - for line in iter(f.readline, ''): - line = line.strip() - - if re_group.match(line): - groups.append(Group(line[8:])) - - elif not len(line): - desc = [] - - elif line == '//': - desc.append('') - - elif line.startswith('// '): - desc.append(line[3:]) - - elif re_option.match(line): - n, d = f.readline().split(';') - o = Option(n, extract_default(d.strip()), line, desc) - groups[-1].append(o) - - replacements = { - u'##BANNER##': write_banner, - u'##DECLARATIONS##': write_declarations, - u'##REGISTRATIONS##': write_registrations, - } - - with io.open(args.output, 'wt', encoding='utf-8') as out: - with io.open(args.template, 'rt', encoding='utf-8') as t: - for line in t: - directive = line.strip() - if directive in replacements: - replacements[directive](out, args) - else: - out.write(line) - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - - -if __name__ == '__main__': - main() diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_punctuator_table.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_punctuator_table.py deleted file mode 100755 index f3d90081..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_punctuator_table.py +++ /dev/null @@ -1,189 +0,0 @@ -#! /usr/bin/env python -# -# Creates a possibly faster lookup table for tokens, etc. -# -# @author Ben Gardner -# @author Matthew Woehlke -# @license GPL v2+ -# -import argparse -import os -import sys - - -# ----------------------------------------------------------------------------- -def scan_file(file_path): - cur_token = '' - token_idx = 0 - args = [] - - fd = open(file_path, 'r') - for line in fd: - line = line.strip() - if line.startswith('static const chunk_tag_t'): - idx = line.find('[') - if idx > 0: - cur_token = line[25:idx].strip() - token_idx = 0 - else: - if len(cur_token) > 0: - idx1 = line.find('{') - idx2 = line.find('CT_') - if idx1 >= 0 and idx2 > idx1: - tok = line[idx1 + 1:idx2].strip() - if tok.startswith('R"'): - pos_paren_open = tok.find('(') - pos_paren_close = tok.rfind(')') - - if pos_paren_open == -1 or pos_paren_close == -1: - sys.stderr.write( - 'raw string parenthesis not found\n') - sys.exit(-1) - - tok = tok[pos_paren_open+1:pos_paren_close] - else: - tok = tok[1:-2] # strip off open quotes and commas - args.append([tok, '%s[%d]' % (cur_token, token_idx)]) - token_idx += 1 - return args - - -# ----------------------------------------------------------------------------- -def build_table(db, prev, arr): - # do the current level first - k = sorted(db) - if len(k) <= 0: - return - k.sort() - - start_idx = len(arr) - num_left = len(k) - - for i in k: - en = db[i] - # [ char, full-string, left-in-group, next_index, table-entry ] - num_left -= 1 - arr.append([en[0], prev + en[0], num_left, 0, en[2]]) - - # update the one-up level index - if len(prev) > 0: - for idx in range(0, len(arr)): - if arr[idx][1] == prev: - arr[idx][3] = start_idx - break - - # Now do each sub level - for i in k: - en = db[i] - build_table(en[3], prev + en[0], arr) - - -# ----------------------------------------------------------------------------- -def add_to_db(entry, db_top): - """ - find or create the entry for the first char - """ - strng = entry[0] - db_cur = db_top - for idx in range(0, len(strng)): - if not strng[idx] in db_cur: - db_cur[strng[idx]] = [strng[idx], 0, None, {}] - - dbe = db_cur[strng[idx]] - - if idx == len(strng) - 1: - dbe[2] = entry - else: - db_cur = dbe[3] - - -# ----------------------------------------------------------------------------- -def quote(s): - return '\'{}\''.format(s) - - -# ----------------------------------------------------------------------------- -def escape(s): - return quote(s.replace('\'', '\\\'')) - - -# ----------------------------------------------------------------------------- -def write_entry(out, max_len, ch, left_in_group, next_idx, tag, idx, tok): - out.write( - ' {{ {:>4}, {:>3d}, {:>3d}, {:{}} }}, // {:3d}: {}'.format( - ch, left_in_group, next_idx, tag, max_len, idx, tok).rstrip()) - out.write('\n') - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser(description='Generate punctuator_table.h') - parser.add_argument('output', type=str, - help='location of punctuator_table.h to write') - parser.add_argument('header', type=str, - help='location of symbols_table.h to read') - args = parser.parse_args() - - root = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) - pl = scan_file(args.header) - pl.sort() - - db = {} - for a in pl: - add_to_db(a, db) - - arr = [] - build_table(db, '', arr) - - max_len = len('nullptr') - for i in arr: - rec = i[4] - if rec is not None and (len(rec[1]) + 1) > max_len: - max_len = len(rec[1]) + 1 - - in_name = os.path.basename(args.header) - out_name = os.path.basename(args.output) - guard = out_name.replace('.', '_').upper() - - with open(args.output, 'wt') as out: - out.write( - '/**\n' - ' * @file {out_name}\n' - ' * Automatically generated by <code>{script}</code>\n' - ' * from {in_name}.\n' - ' */\n' - '\n' - '#ifndef SRC_{guard}_\n' - '#define SRC_{guard}_\n' - '\n' - '// *INDENT-OFF*\n' - 'static const lookup_entry_t punc_table[] =\n' - '{{\n'.format( - in_name=in_name, out_name=out_name, guard=guard, - script=os.path.relpath(__file__, root))) - - idx = 0 - - for i in arr: - rec = i[4] - if len(i[0]) == 0: - write_entry(out, max_len, '0', '0', '0', 'nullptr', idx, '') - elif rec is None: - write_entry(out, max_len, escape(i[0]), i[2], i[3], - 'nullptr', idx, quote(i[1])) - else: - write_entry(out, max_len, escape(i[0]), i[2], i[3], - '&' + rec[1], idx, quote(i[1])) - idx += 1 - - out.write( - '}};\n' - '// *INDENT-ON*\n' - '\n' - '#endif /* SRC_{guard}_ */\n'.format(guard=guard)) - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - - -if __name__ == '__main__': - main() diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_version.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_version.py deleted file mode 100755 index 14e20018..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/make_version.py +++ /dev/null @@ -1,98 +0,0 @@ -#!/usr/bin/env python -# -# Rebuilds the version using git describe -# -from sys import exit -from subprocess import Popen, check_call, PIPE -from os.path import join, dirname, abspath, exists -from os import name as os_name -from sys import argv, exit -import re - -if os_name == 'nt': - EX_OK = 0 - EX_USAGE = 64 - EX_IOERR = 74 -else: - from os import EX_IOERR, EX_OK, EX_USAGE - -def main(args): - root = dirname(dirname(abspath(__file__))) - git_path = join(root, '.git') - hg_path = join(root, '.hg') - - txt = "" - error_txt= "" - - if exists(git_path): - try: - proc = Popen(['git', 'describe', '--always', '--dirty'], stdout=PIPE, stderr=PIPE, cwd=root) - txt_b, error_txt_b = proc.communicate() - txt = txt_b.decode("UTF-8").strip().lower() - error_txt = "%d: %s" % (proc.returncode, error_txt_b.decode("UTF-8").strip().lower()) - except: - print("Failed to retrieve version from git") - exit(EX_IOERR) - elif exists(hg_path): - try: - check_call(['hg', 'gexport']) - proc0 = Popen(['hg', '--config', 'defaults.log=', 'log', '-r', '.', '--template', '{gitnode}'], stdout=PIPE, stderr=PIPE, cwd=root) - node_b, error_txt_b = proc0.communicate() - node = node_b.decode("UTF-8") - error_txt = "%d: %s" % (proc0.returncode, error_txt_b.decode("UTF-8").strip().lower()) - - proc1 = Popen(['git', '--git-dir=.hg/git', 'describe', '--long', '--tags', '--always', node], stdout=PIPE, stderr=PIPE, cwd=root) - txt_b, error_txt_b = proc1.communicate() - txt = txt_b.decode("UTF-8").lower() - error_txt += ", %d: %s" % (proc1.returncode, error_txt_b.decode("UTF-8").strip().lower()) - except: - print("Failed to retrieve version from hg") - exit(EX_IOERR) - else: - print("Unknown version control system in '%s'." % root) - exit(EX_USAGE) - - version_pattern = re.compile(r""" - ^ - ( #1: full match - uncrustify- - (\d+\.\d+(\.\d+)?) #2: version 0.64.2 (,#3 optional 3rd nr) - ( #4: additional version info (long string format) - -(\d+) #5: tag commit distance - -g(\w{7,}) #g-prefix + #6: commithash - )? - | - (\w{7,}) #7: commithash only format (last N commits pulled and no tag available) - ) - (-(dirty))? #9: optional dirty specifier (#8,) - $ - """, re.X) - r_match = version_pattern.match(txt) - - if r_match is None: - print("Regex version match failed on: '%s' (%s)" % (txt, error_txt)) - exit(EX_IOERR) - - if r_match.group(2) is not None: - string_groups = [r_match.group(2)] - if r_match.group(5) is not None and r_match.group(6) is not None: - string_groups.append(r_match.group(5)) - string_groups.append(r_match.group(6)) - else: - string_groups = [r_match.group(7)] - - if r_match.group(9) is not None: - string_groups.append(r_match.group(9)) - - - for g in string_groups: - if g is None: - print("Unexpected empty regex group") - exit(EX_IOERR) - - print("%s" % "-".join(string_groups)) - return EX_OK - - -if __name__ == "__main__": - main(argv[1:]) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/option_reducer.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/option_reducer.py deleted file mode 100755 index 403ff92b..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/option_reducer.py +++ /dev/null @@ -1,1125 +0,0 @@ -#!/usr/bin/python -""" -option_reducer.py - -reduces options in a given config file to the minimum while still maintaining -desired formatting - -:author: Daniel Chumak -:license: GPL v2+ -""" - -# Possible improvements: -# - parallelize add_back() -# - (maybe) reduce amount of written config file, see Uncrustify --set - -from __future__ import print_function # python >= 2.6 -import argparse - -from os import name as os_name, sep as os_path_sep, fdopen as os_fdopen, \ - remove as os_remove -from os.path import exists, join as path_join -from subprocess import Popen, PIPE -from sys import exit as sys_exit, stderr, stdout -from shutil import rmtree -from multiprocessing import cpu_count -from tempfile import mkdtemp, mkstemp -from contextlib import contextmanager -from collections import OrderedDict -from threading import Timer -from multiprocessing.pool import Pool -from itertools import combinations - -FLAGS = None -NULL_DEV = "/dev/null" if os_name != "nt" else "nul" - - -def enum(**enums): - return type('Enum', (), enums) - - -RESTULTSFLAG = enum(NONE=0, REMOVE=1, KEEP=2) -ERROR_CODE = enum(NONE=0, FLAGS=200, SANITY0=201, SANITY1=202) -MODES = ("reduce", "no-default") - - -@contextmanager -def make_temp_directory(): - """ - Wraps tempfile.mkdtemp to use it inside a with statement that auto deletes - the temporary directory with its content after the with block closes - - - :return: str - ---------------------------------------------------------------------------- - path to the generated directory - """ - temp_dir = mkdtemp() - try: - yield temp_dir - finally: - rmtree(temp_dir) - - -@contextmanager -def make_raw_temp_file(*args, **kwargs): - """ - Wraps tempfile.mkstemp to use it inside a with statement that auto deletes - the file after the with block closes - - - Parameters - ---------------------------------------------------------------------------- - :param args, kwargs: - arguments passed to mkstemp - - - :return: int, str - ---------------------------------------------------------------------------- - the file descriptor and the file path of the created temporary file - """ - fd, tmp_file_name = mkstemp(*args, **kwargs) - try: - yield (fd, tmp_file_name) - finally: - os_remove(tmp_file_name) - - -@contextmanager -def open_fd(*args, **kwargs): - """ - Wraps os.fdopen to use it inside a with statement that auto closes the - generated file descriptor after the with block closes - - - Parameters - ---------------------------------------------------------------------------- - :param args, kwargs: - arguments passed to os.fdopen - - - :return: TextIOWrapper - ---------------------------------------------------------------------------- - open file object connected to the file descriptor - """ - fp = os_fdopen(*args, **kwargs) - try: - yield fp - finally: - fp.close() - - -def term_proc(proc, timeout): - """ - helper function to terminate a process - - - Parameters - ---------------------------------------------------------------------------- - :param proc: process object - the process object that is going to be terminated - - :param timeout: dictionary - a dictionary (used as object reference) to set a flag that indicates - that the process is going to be terminated - """ - timeout["value"] = True - proc.terminate() - - -def uncrustify(unc_bin_path, cfg_file_path, unformatted_file_path, - lang=None, debug_file=None, check=False): - """ - executes Uncrustify and captures its stdout - - - Parameters - ---------------------------------------------------------------------------- - :param unc_bin_path: str - path to the Uncrustify binary - - :param cfg_file_path: str - path to a config file for Uncrustify - - :param unformatted_file_path: str - path to a file that is going to be formatted - - :param lang: str / None - Uncrustifys -l argument - - :param debug_file: str / None - Uncrustifys -p argument - - :param check: bool - Used to control whether Uncrustifys --check is going to be used - - - :return: str / None - ---------------------------------------------------------------------------- - returns the stdout from Uncrustify or None if the process takes to much - time (set to 5 sec) - """ - - args = [unc_bin_path, "-q", "-c", cfg_file_path, '-f', - unformatted_file_path] - if lang: - args.extend(("-l", lang)) - if debug_file: - args.extend(('-p', debug_file)) - if check: - args.append('--check') - - proc = Popen(args, stdout=PIPE, stderr=PIPE) - - timeout = {"value": False} - timer = Timer(5, term_proc, [proc, timeout]) - timer.start() - - output_b, error_txt_b = proc.communicate() - - timer.cancel() - - if timeout["value"]: - print("uncrustify proc timeout: %s" % ' '.join(args), file=stderr) - return None - - error = error_txt_b.decode("UTF-8") - if error: - print("Uncrustify %s stderr:\n %s" % (unformatted_file_path, error), - file=stderr) - - return output_b - - -def same_expected_generated(formatted_path, unc_bin_path, cfg_file_path, - input_path, lang=None): - """ - Calls uncrustify and compares its generated output with the content of a - file - - - Parameters - ---------------------------------------------------------------------------- - :param formatted_path: str - path to a file containing the expected content - - :params unc_bin_path, cfg_file_path, input_path, lang: str, str, str, - str / None - see uncrustify() - - - :return: bool - ---------------------------------------------------------------------------- - True if the strings match, False otherwise - """ - - expected_string = '' - with open(formatted_path, 'rb') as f: - expected_string = f.read() - - formatted_string = uncrustify(unc_bin_path, cfg_file_path, input_path, lang) - - return True if formatted_string == expected_string else False - - -def process_uncrustify(args): - """ - special wrapper for same_expected_generated() - - accesses global var(s): RESTULTSFLAG - - - Parameters - ---------------------------------------------------------------------------- - :param args: list / tuple< int, ... > - this function is intended to be called by multiprocessing.pool.map() - therefore all arguments are inside a list / tuple: - id: int - an index number needed by the caller to differentiate runs - - other parameters: - see same_expected_generated() - - - :return: tuple< int, RESTULTSFLAG > - ---------------------------------------------------------------------------- - returns a tuple containing the id and a RESTULTSFLAG, REMOVE if both - strings are equal, KEEP if not - """ - - id = args[0] - res = same_expected_generated(*args[1:]) - - return id, RESTULTSFLAG.REMOVE if res else RESTULTSFLAG.KEEP - - -def write_config_file(args): - """ - Writes all but one excluded option into a config file - - - Parameters - ---------------------------------------------------------------------------- - :param args: list / tuple< list< tuple< str, str > >, str, int > - this function is intended to be called by multiprocessing.pool.map() - therefore all arguments are inside a list / tuple: - - config_list: list< tuple< str, str > > - a list of tuples containing option names and values - - tmp_dir: str - path to a directory in which the config file is going to be - written - - exclude_idx: int - index for an option that is not going to be written into the - config file - """ - - config_list, tmp_dir, exclude_idx = args - - with open("%s%suncr-%d.cfg" % (tmp_dir, os_path_sep, exclude_idx), - 'w') as f: - print_config(config_list, target_file_obj=f, exclude_idx=exclude_idx) - - -def write_config_file2(args): - """ - Writes two option lists into a config file - - - Parameters - ---------------------------------------------------------------------------- - :param args: list< tuple< str, str > >, - list< tuple< str, str > >, str, int - this function is intended to be called by multiprocessing.pool.map() - therefore all arguments are inside a list / tuple: - - config_list: list< tuple< str, str > > - the first list of tuples containing option names and values - - test_list: list< tuple< str, str > > - the second list of tuples containing option names and values - - tmp_dir: str - path to a directory in which the config file is going to be - written - - idx: int - index that is going to be used for the filename - """ - - config_list0, config_list1, tmp_dir, idx = args - - with open("%s%suncr-r-%d.cfg" % (tmp_dir, os_path_sep, idx), 'w') as f: - print_config(config_list0, target_file_obj=f) - print("", end='\n', file=f) - print_config(config_list1, target_file_obj=f) - - -def gen_multi_combinations(elements, N): - """ - generator function that generates, based on a set of elements, all - combinations of 1..N elements - - - Parameters - ---------------------------------------------------------------------------- - :param elements: list / tuple - a list of elements from which the combinations will be generated - - :param N: - the max number of element in a combination - - - :return: list - ---------------------------------------------------------------------------- - yields a single combination of the elements - - >>> gen_multi_combinations(["a", "b", "c"], 3) - (a); (b); (c); (a,b); (a,c); (b,c); (a,b,c) - """ - - fields = len(elements) - if N > fields: - raise Exception("Error: N > len(options)") - if N <= 0: - raise Exception("Error: N <= 0") - - for n in range(1, N + 1): - yield combinations(elements, n) - - -def add_back(unc_bin_path, input_files, formatted_files, langs, options_r, - options_k, tmp_dir): - """ - lets Uncrustify format files with generated configs files until all - formatted files match their according expected files. - - Multiple config files are generated based on a (base) list of Uncrustify - options combined with additional (new) options derived from combinations of - another list of options. - - - accesses global var(s): RESTULTSFLAG - - - Parameters - ---------------------------------------------------------------------------- - :param unc_bin_path: str - path to the Uncrustify binary - - :param input_files: list / tuple< str > - a list containing paths to a files that are going to be formatted - - :param formatted_files: list / tuple< str > - a list containing paths to files containing the expected contents - - :param langs: list / tuple< str > / None - a list of languages the files, used as Uncrustifys -l argument - can be None or shorter than the amount of provided files - - :param options_r: list< tuple< str, str > > - the list of options from which combinations will be derived - - :param options_k: list< tuple< str, str > > - the (base) list of Uncrustify options - - :param tmp_dir: str - the directory in which the config files will be written to - - - :return: list< tuple< str, str > > / None - ---------------------------------------------------------------------------- - list of additional option that were needed to generate matching file - contents - """ - - lang_max_idx = -1 if langs is None else len(langs) - 1 - file_len = len(input_files) - - if len(formatted_files) != file_len: - raise Exception("len(input_files) != len(formatted_files)") - - for m_combination in gen_multi_combinations(options_r, len(options_r)): - for idx, (r_combination) in enumerate(m_combination): - write_config_file2((options_k, r_combination, tmp_dir, idx)) - - cfg_file_path = "%s%suncr-r-%d.cfg" % (tmp_dir, os_path_sep, idx) - res = [] - - for file_idx in range(file_len): - lang = None if idx > lang_max_idx else langs[file_idx] - - r = process_uncrustify( - (0, formatted_files[file_idx], unc_bin_path, cfg_file_path, - input_files[file_idx], lang)) - res.append(r[1]) - - # all files, flag = remove -> option can be removed -> equal output - if res.count(RESTULTSFLAG.REMOVE) == len(res): - return r_combination - return None - - -def sanity_raw_run(args): - """ - wrapper for same_expected_generated(), prints error message if the config - file does not generate the expected result - - Parameters - ---------------------------------------------------------------------------- - :param args: - see same_expected_generated - - - :return: - ---------------------------------------------------------------------------- - see same_expected_generated - """ - res = same_expected_generated(*args) - - if not res: - formatted_file_path = args[0] - config_file_path = args[2] - input_file_path = args[3] - - print("\nprovided config does not create formatted source file:\n" - " %s\n %s\n->| %s" - % (input_file_path, config_file_path, formatted_file_path), - file=stderr) - return res - - -def sanity_run(args): - """ - wrapper for same_expected_generated(), prints error message if the config - file does not generate the expected result - - - Parameters - ---------------------------------------------------------------------------- - :param args: - see same_expected_generated - - - :return: - ---------------------------------------------------------------------------- - see same_expected_generated - """ - res = same_expected_generated(*args) - - if not res: - formatted_file_path = args[0] - input_file_path = args[3] - - print("\ngenerated config does not create formatted source file:\n" - " %s\n %s" - % (input_file_path, formatted_file_path), file=stderr) - return res - - -def sanity_run_splitter(uncr_bin, config_list, input_files, formatted_files, - langs, tmp_dir, jobs): - """ - writes config option into a file and tests if every input file is formatted - so that is matches the content of the according expected file - - - Parameters - ---------------------------------------------------------------------------- - :param uncr_bin: str - path to the Uncrustify binary - - :param config_list: list< tuple< str, str > > - a list of tuples containing option names and values - - :param input_files: list / tuple< str > - a list containing paths to a files that are going to be formatted - - :param formatted_files: list / tuple< str > - a list containing paths to files containing the expected contents - - :param langs: list / tuple< str > / None - a list of languages the files, used as Uncrustifys -l argument - can be None or shorter than the amount of provided files - - :param tmp_dir: str - the directory in which the config files will be written to - - :param jobs: int - number of processes to use - - - :return: bool - ---------------------------------------------------------------------------- - True if all files generate correct results, False oterhwise - """ - - file_len = len(input_files) - if len(formatted_files) != file_len: - raise Exception("len(input_files) != len(formatted_files)") - - gen_cfg_path = path_join(tmp_dir, "gen.cfg") - with open(gen_cfg_path, 'w') as f: - print_config(config_list, target_file_obj=f) - - lang_max_idx = -1 if langs is None else len(langs) - 1 - args = [] - - for idx in range(file_len): - lang = None if idx > lang_max_idx else langs[idx] - - args.append((formatted_files[idx], uncr_bin, gen_cfg_path, - input_files[idx], lang)) - - pool = Pool(processes=jobs) - sr = pool.map(sanity_run, args) - - return False not in sr - - -def print_config(config_list, target_file_obj=stdout, exclude_idx=()): - """ - prints config options into a config file - - - Parameters - ---------------------------------------------------------------------------- - :param config_list: list< tuple< str, str > > - a list containing pairs of option names and option values - - :param target_file_obj: file object - see file param of print() - - :param exclude_idx: int / list< int > - index of option(s) that are not going to be printed - """ - - if not config_list: - return - config_list_len = len(config_list) - - # check if exclude_idx list is empty -> assign len - if type(exclude_idx) in (list, tuple) and not exclude_idx: - exclude_idx = [config_list_len] - else: - # sort it, unless it is an int -> transform into a list - try: - exclude_idx = sorted(exclude_idx) - except TypeError: - exclude_idx = [exclude_idx] - - # extracted first loop round: - # do not print '\n' for the ( here non-existing) previous line - if exclude_idx[0] != 0: - print("%s = %s" % (config_list[0][0].ljust(31, ' '), config_list[0][1]), - end='', file=target_file_obj) - # also print space if a single option was provided and it is going to be - # excluded. This is done in order to be able to differentiate between - # --empty-nochange and the case where all options can be removed - elif config_list_len == 1: - print(' ', end='', file=target_file_obj) - return - - start_idx = 1 - for end in exclude_idx: - end = min(end, config_list_len) - - for idx in range(start_idx, end): - print("\n%s = %s" - % (config_list[idx][0].ljust(31, ' '), config_list[idx][1]), - end='', file=target_file_obj) - - start_idx = min(end + 1, config_list_len) - - # after - for idx in range(start_idx, config_list_len): - print("\n%s = %s" - % (config_list[idx][0].ljust(31, ' '), config_list[idx][1]), - end='', file=target_file_obj) - - -def get_non_default_options(unc_bin_path, cfg_file_path): - """ - calls Uncrustify to generate a debug file from which a config only with - non default valued options are extracted - - accesses global var(s): NULL_DEV - - - Parameters - ---------------------------------------------------------------------------- - :param unc_bin_path: str - path to the Uncrustify binary - - :param cfg_file_path: str - path to a config file for Uncrustify - - - :return: list< str > - ---------------------------------------------------------------------------- - amount of lines in the provided and shortened config - """ - lines = [] - - with make_raw_temp_file(suffix='.unc') as (fd, file_path): - # make debug file - uncrustify(unc_bin_path, cfg_file_path, NULL_DEV, debug_file=file_path, - check=True) - - # extract non comment lines -> non default config lines - with open_fd(fd, 'r') as fp: - lines = fp.read().splitlines() - lines = [line for line in lines if not line[:1] == '#'] - - return lines - - -def parse_config_file(file_obj): - """ - Reads in a Uncrustify config file - - - Parameters - ---------------------------------------------------------------------------- - :param file_obj: - the file object of an opened config file - - - :return: list< tuple< str, str > > - ---------------------------------------------------------------------------- - a list containing pairs of option names and option values - """ - # dict used to only save the last option setting if the same option occurs - # multiple times, without this: - # optionA0 can be removed because optionA1 = s0, and - # optionA1 can be removed because optionA0 = s0 - # -> optionA0, optionA1 are both removed - config_map = OrderedDict() - - # special keys may not have this limitation, as for example - # 'set x y' and 'set x z' do not overwrite each other - special_keys = {'macro-open', 'macro-else', 'macro-close', 'set', 'type', - 'file_ext', 'define'} - special_list = [] - - for line in file_obj: - # cut comments - pound_pos = line.find('#') - if pound_pos != -1: - line = line[:pound_pos] - - split_pos = line.find('=') - if split_pos == -1: - split_pos = line.find(' ') - if split_pos == -1: - continue - - key = line[:split_pos].strip() - value = line[split_pos + 1:].strip() - - if key in special_keys: - special_list.append((key, value)) - else: - config_map[key] = value - - config_list = list(config_map.items()) - config_list += special_list - - return config_list - - -def count_lines(file_path): - """ - returns the count of lines in a file by counting '\n' chars - - Parameters - ---------------------------------------------------------------------------- - :param file_path: str - file in which the lines will be counted - - - :return: int - ---------------------------------------------------------------------------- - number a lines - """ - in_count = 0 - with open(file_path, 'r') as f: - in_count = f.read().count('\n') + 1 - return in_count - - -def reduce(options_list): - """ - Reduces the given options to a minimum - - accesses global var(s): FLAGS, RESTULTSFLAG, ERROR_CODE - - Parameters - ---------------------------------------------------------------------------- - :param options_list: list< tuple< str, str > > - the list of options that are going to be reduced - - :return: int, list< tuple< str, str > > - status return code, reduced options - """ - config_list_len = len(options_list) - ret_flag = ERROR_CODE.NONE - - file_count = len(FLAGS.input_file_path) - lang_max_idx = -1 if FLAGS.lang is None else len(FLAGS.lang) - 1 - - pool = Pool(processes=FLAGS.jobs) - with make_temp_directory() as tmp_dir: - # region sanity run ---------------------------------------------------- - args = [] - for idx in range(file_count): - lang = None if idx > lang_max_idx else FLAGS.lang[idx] - - args.append((FLAGS.formatted_file_path[idx], - FLAGS.uncrustify_binary_path, FLAGS.config_file_path, - FLAGS.input_file_path[idx], lang)) - sr = pool.map(sanity_raw_run, args) - del args[:] - - if False in sr: - return ERROR_CODE.SANITY0, [] - del sr[:] - - # endregion - # region config generator loop ----------------------------------------- - args = [] - - for e_idx in range(config_list_len): - args.append((options_list, tmp_dir, e_idx)) - pool.map(write_config_file, args) - - del args[:] - - # endregion - # region main loop ----------------------------------------------------- - args = [] - jobs = config_list_len * file_count - - for idx in range(jobs): - file_idx = idx // config_list_len - option_idx = idx % config_list_len - - cfg_file_path = "%s%suncr-%d.cfg" \ - % (tmp_dir, os_path_sep, option_idx) - lang = None if idx > lang_max_idx else FLAGS.lang[file_idx] - - args.append((idx, FLAGS.formatted_file_path[file_idx], - FLAGS.uncrustify_binary_path, cfg_file_path, - FLAGS.input_file_path[file_idx], lang)) - - results = pool.map(process_uncrustify, args) - del args[:] - # endregion - # region clean results ------------------------------------------------- - option_flags = [RESTULTSFLAG.NONE] * config_list_len - - for r in results: - idx = r[0] - flag = r[1] - - option_idx = idx % config_list_len - - if option_flags[option_idx] == RESTULTSFLAG.KEEP: - continue - - option_flags[option_idx] = flag - del results[:] - # endregion - - options_r = [options_list[idx] for idx, x in enumerate(option_flags) - if x == RESTULTSFLAG.REMOVE] - options_list = [options_list[idx] for idx, x in enumerate(option_flags) - if x == RESTULTSFLAG.KEEP] - - del option_flags[:] - - # region sanity run ---------------------------------------------------- - # options can be removed one at a time generating appropriate results, - # oddly enough sometimes a config generated this way can fail when a - # combination of multiple options is missing - s_flag = True - if options_r: - s_flag = sanity_run_splitter( - FLAGS.uncrustify_binary_path, options_list, - FLAGS.input_file_path, FLAGS.formatted_file_path, FLAGS.lang, - tmp_dir, FLAGS.jobs) - - if not s_flag: - ret_flag = ERROR_CODE.SANITY1 - print("\n\nstumbled upon complex option dependencies in \n" - " %s\n" - "trying to add back minimal amount of removed options\n" - % FLAGS.config_file_path, file=stderr) - - ret_options = add_back( - FLAGS.uncrustify_binary_path, FLAGS.input_file_path, - FLAGS.formatted_file_path, FLAGS.lang, options_r, - options_list, tmp_dir) - - if ret_options: - options_list.extend(ret_options) - - s_flag = sanity_run_splitter( - FLAGS.uncrustify_binary_path, options_list, - FLAGS.input_file_path, FLAGS.formatted_file_path, - FLAGS.lang, tmp_dir, FLAGS.jobs) - - if s_flag: - print("Success!", file=stderr) - ret_flag = ERROR_CODE.NONE - # endregion - return ret_flag, options_list if ret_flag == ERROR_CODE.NONE else [] - - -def reduce_mode(): - """ - the mode that minimizes a config file as much as possible - - accesses global var(s): FLAGS, ERROR_CODE - """ - ret_flag = ERROR_CODE.NONE - option_list = {} - - # gen & parse non default config - lines = get_non_default_options(FLAGS.uncrustify_binary_path, - FLAGS.config_file_path) - option_list = parse_config_file(lines) - config_list_len = len(option_list) - - config_lines_init = count_lines(FLAGS.config_file_path) - config_lines_ndef = len(lines) - del lines[:] - - # early return if all options are already removed at this point - if config_list_len == 0: - if not FLAGS.empty_nochange \ - or (config_lines_init - config_lines_ndef) > 0: - if not FLAGS.quiet: - print("\n%s" % '# '.ljust(78, '-')) - - print(" ") - - if not FLAGS.quiet: - print("%s" % '# '.ljust(78, '-')) - print("# initial config lines: %d,\n" - "# default options and unneeded lines: %d,\n" - "# unneeded options: 0,\n" - "# kept options: 0" - % (config_lines_init, config_lines_init)) - print("ret_flag: 0", file=stderr) - return ERROR_CODE.NONE - - # gen reduced options - config_lines_redu = -1 - for i in range(FLAGS.passes): - old_config_lines_redu = config_lines_redu - - ret_flag, option_list = reduce(option_list) - config_lines_redu = len(option_list) - - if ret_flag != ERROR_CODE.NONE \ - or config_lines_redu == old_config_lines_redu: - break - - if ret_flag == ERROR_CODE.NONE: - # use the debug file trick again to get correctly sorted options - with make_raw_temp_file(suffix='.unc') as (fd, file_path): - with open_fd(fd, 'w') as f: - print_config(option_list, target_file_obj=f) - - lines = get_non_default_options(FLAGS.uncrustify_binary_path, - file_path) - option_list = parse_config_file(lines) - - # print output + stats - if not FLAGS.empty_nochange or config_lines_ndef != config_lines_redu: - if not FLAGS.quiet: - print("\n%s" % '# '.ljust(78, '-')) - - print_config(option_list) - - if not FLAGS.quiet: - print("\n%s" % '# '.ljust(78, '-')) - print("# initial config lines: %d,\n" - "# default options and unneeded lines: %d,\n" - "# unneeded options: %d,\n" - "# kept options: %d" - % (config_lines_init, - config_lines_init - config_lines_ndef, - config_lines_ndef - config_lines_redu, - config_lines_redu)) - - print("ret_flag: %d" % ret_flag, file=stderr) - return ret_flag - - -def no_default_mode(): - """ - the mode removes all unnecessary lines and options with default values - - accesses global var(s): FLAGS, ERROR_CODE - """ - - lines = get_non_default_options(FLAGS.uncrustify_binary_path, - FLAGS.config_file_path, ) - config_lines_ndef = len(lines) - config_lines_init = count_lines(FLAGS.config_file_path) - - if not FLAGS.empty_nochange or (config_lines_ndef != config_lines_init): - if not FLAGS.quiet: - print("%s" % '# '.ljust(78, '-')) - - options_str = '\n'.join(lines) - if not options_str: - print(" ") - else: - print(options_str, file=stdout) - - if not FLAGS.quiet: - print("%s" % '# '.ljust(78, '-')) - print("# initial config lines: %d,\n" - "# default options and unneeded lines: %d,\n" - % (config_lines_init, config_lines_init - config_lines_ndef)) - - return ERROR_CODE.NONE - - -def main(): - """ - calls the mode that was specified by the -m script argument, - defaults to reduce_mode if not provided or unknown mode - - accesses global var(s): MODES, FLAGS - - - :return: int - ---------------------------------------------------------------------------- - return code - """ - if FLAGS.mode == MODES[1]: - return no_default_mode() - - return reduce_mode() - - -def valid_file(arg_parser, *args): - """ - checks if on of the provided paths is a file - - - Parameters - ---------------------------------------------------------------------------- - :param arg_parser: - argument parser object that is called if no file is found - - :param args: list< str > - a list of file path that is going to be checked - - - :return: str - ---------------------------------------------------------------------------- - path to an existing file - """ - arg = None - found_flag = False - for arg in args: - if exists(arg): - found_flag = True - break - if not found_flag: - arg_parser.error("file(s) do not exist: %s" % args) - - return arg - - -if __name__ == "__main__": - """ - parses all script arguments and calls main() - - accesses global var(s): FLAGS, ERROR_CODE, MODES - """ - arg_parser = argparse.ArgumentParser() - - group_general = arg_parser.add_argument_group( - 'general options', 'Options used by both modes') - - group_general.add_argument( - '-q', '--quiet', - default=False, - action='store_true', - help='Whether or not messages, other than the actual config output, ' - 'should be printed to stdout.' - ) - group_general.add_argument( - '--empty-nochange', - default=False, - action='store_true', - help='Do not print anything to stdout if no options could be removed' - ) - group_general.add_argument( - '-m', '--mode', - type=str, - choices=MODES, - default=MODES[0], - help="The script operation mode. Defaults to '%s'" % MODES[0] - ) - group_general.add_argument( - '-b', '--uncrustify_binary_path', - metavar='<path>', - type=lambda x: valid_file( - arg_parser, x, - "../build/uncrustify.exe", - "../build/Debug/uncrustify", - "../build/Debug/uncrustify.exe", - "../build/Release/uncrustify", - "../build/Release/uncrustify.exe"), - default="../build/uncrustify", - help="The Uncrustify binary file path. Is searched in known locations " - "in the 'Uncrustify/build/' directory if no <path> is provided." - ) - group_general.add_argument( - '-c', '--config_file_path', - metavar='<path>', - type=lambda x: valid_file(arg_parser, x), - required=True, - help='Path to the config file.' - ) - - group_reduce = arg_parser.add_argument_group( - 'reduce mode', 'Options to reduce configuration file options') - - group_reduce.add_argument( - '-i', '--input_file_path', - metavar='<path>', - type=lambda x: valid_file(arg_parser, x), - nargs='+', - action='append', - help="Path to the unformatted source file. " - "Required if mode '%s' is used" % MODES[0] - ) - group_reduce.add_argument( - '-f', '--formatted_file_path', - metavar='<path>', - type=lambda x: valid_file(arg_parser, x), - nargs='+', - action='append', - help="Path to the formatted source file. " - "Required if mode '%s' is used" % MODES[0] - ) - group_reduce.add_argument( - '-l', '--lang', - metavar='<str>', - nargs='+', - required=False, - action='append', - help='Uncrustify processing language for each input file' - ) - group_reduce.add_argument( - '-j', '--jobs', - metavar='<nr>', - type=int, - default=cpu_count(), - help='Number of concurrent jobs.' - ) - group_reduce.add_argument( - '-p', '--passes', - metavar='<nr>', - type=int, - default=5, - help='Max. number of cleaning passes.' - ) - - group_no_default = arg_parser.add_argument_group( - 'no-default mode', 'Options to remove configuration file option with ' - 'default values: ~~_Currently only the general' - ' options are used for this mode_~~') - FLAGS, unparsed = arg_parser.parse_known_args() - - if FLAGS.lang is not None: - FLAGS.lang = [j for i in FLAGS.lang for j in i] - - if FLAGS.mode == MODES[0]: - if not FLAGS.input_file_path or not FLAGS.formatted_file_path: - arg_parser.error("Flags -f and -i are required in Mode '%s'!" - % MODES[0]) - sys_exit(ERROR_CODE.FLAGS) - - # flatten 2 dimensional args: -f p -f p -f p -f p0 p1 p2 -> [[],[], ...] - FLAGS.input_file_path = [j for i in FLAGS.input_file_path for j in i] - - FLAGS.formatted_file_path = [j for i in - FLAGS.formatted_file_path for j in i] - - if len(FLAGS.input_file_path) != len(FLAGS.formatted_file_path): - print("Unequal amount of input and formatted file paths.", - file=stderr) - sys_exit(ERROR_CODE.FLAGS) - - sys_exit(main()) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/au-sm123.lnt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/au-sm123.lnt deleted file mode 100644 index 6eaf9a6b..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/au-sm123.lnt +++ /dev/null @@ -1,237 +0,0 @@ -/* Date Stamp */ -d"_lint_au_sm123_lnt=au-sm123.lnt modified 5-Jan-2006" -/* To document usage use: -message( "Using " _lint_au_sm123_lnt ) */ -// --------------------------------------------------------------------- -// This file is provided by Gimpel Software (www.gimpel.com) for use with -// its products PC-lint and FlexeLint. -// -// Redistribution and use of this file, with or without modification, is -// permitted provided that any such redistribution retains this notice. -// --------------------------------------------------------------------- -// au-sm123.lnt -- Author options - Scott Meyers - -/* - This options file can be used to explicitly activate those - checks advocated in the publications: - - [12] Meyers, Scott, Effective C++, Addison-Wesley, Reading Mass., 1992 - [23] Meyers, Scott, More Effective C++, Addison-Wesley, 1996 - [30] Meyers, Scott, Effective C++ Third Edition, Addison-Wesley, 2005 - - You can use this file directly when linting your programs as in: - - lin au-sm123 files - - Most of the Scott Meyers checks are on by default. The - Elective Notes (19??), however, are not and so this file - is necessary to get the full impact of the Scott Meyers - multi-volume set of recommendations. - - Also, this file explicitly activates those Warnings and - Informationals advocated by Scott Meyers just in case they were - suppressed previously. For example, - - lin -w2 au-sm123 files - - has the effect of removing all Informational messages - other than those reactivated in this file. - - If you do not want code to adhere to all of the Scott Meyers' - checks we recommend that, rather than editing this file, you - include it within a file of your own. For example: let - my-sm.lnt contain - - au-sm123.lnt - -e1932 // allow concrete base classes - - In this way you inherit the checks specified in this file - except for the ones that you wish to specifically exclude. - - Then you can use my-sm.lnt in place of au-sm123.lnt - - You might consider placing this file (au-sm123.lnt) or your own - derivation of it (as shown above) in your global options - file. - - */ - -+e424 // Inappropriate deallocation -- [12, Item 5], [30, Item 16] --append(424, -- Effective C++ #5 & Eff. C++ 3rd Ed. item 16) -+e530 // Symbol not initialized -- [30, Item 4] --append( 530, --- Eff. C++ 3rd Ed. item 4 ) -+e603 // Symbol not initialized -- [30, Item 4] --append( 603, --- Eff. C++ 3rd Ed. item 4 ) -+e605 // Increase in pointer capability -- [12, Item 29] --append(605, -- Effective C++ #29 ) -+e644 // Variable may not have been initialized -- [30, Item 4] --append( 644, --- Eff. C++ 3rd Ed. item 4 ) -+e645 // Symbol may not have been initialized -- [30, Item 4] --append( 645, --- Eff. C++ 3rd Ed. item 4 ) -+e673 // Possibly inappropriate deallocation (Name1) for 'Name2' data. -- [30, Item 16] --append( 673, --- Eff. C++ 3rd Ed. item 16 ) -+e727 // Symbol not explicitly initialized -- [30, Item 4] --append( 727, --- Eff. C++ 3rd Ed. item 4 ) -+e728 // Symbol not explicitly initialized -- [30, Item 4] --append( 728, --- Eff. C++ 3rd Ed. item 4 ) -+e729 // Symbol not explicitly initialized -- [30, Item 4] --append( 729, --- Eff. C++ 3rd Ed. item 4 ) -+e738 // Symbol not explicitly initialized -- [30, Item 4] --append( 738, --- Eff. C++ 3rd Ed. item 4 ) -+e771 // Symbol conceivably not initialized -- [30, Item 4] --append( 771, --- Eff. C++ 3rd Ed. item 4 ) -+e772 // Symbol conceivably not initialized -- [30, Item 4] --append( 772, --- Eff. C++ 3rd Ed. item 4 ) -+e794 // Conceivable use of null pointer -- [12, Item 7] --append(794, -- Effective C++ #7 ) -+e802 // Conceivably passing a null pointer to function -- [12, Item 7] --append(802, -- Effective C++ #7 ) -+e818 // Pointer parameter could be declared ptr to const -- [30, Item 3] --append( 818, --- Eff. C++ 3rd Ed. item 3 ) -+e952 // Parameter could be declared const -- [30, Item 3] --append( 952, --- Eff. C++ 3rd Ed. item 3 ) -+e953 // Variable could be declared as const -- [30, Item 3] --append( 953, --- Eff. C++ 3rd Ed. item 3 ) -+e954 // Pointer variable could be declared as pointing to a const -- [30, Item 3] --append( 954, --- Eff. C++ 3rd Ed. item 3 ) -+e1072 // Reference variable must be initialized -- [30, Item 4] --append( 1072, --- Eff. C++ 3rd Ed. item 4 ) -+e1401 // member symbol not initialized by constructor -- [30, Item 4], [30, Item 13] --append( 1401, --- Eff. C++ 3rd Ed. item 4 & Eff. C++ 3rd Ed. item 13) -+e1402 // member not initialized -- [30, Item 4] --append( 1402, --- Eff. C++ 3rd Ed. item 4 ) -+e1403 // member not initialized -- [30, Item 4] --append( 1403, --- Eff. C++ 3rd Ed. item 4 ) -+e1411 // Member with different signature hides virtual member -- [30, Item 33] --append( 1411, --- Eff. C++ 3rd Ed. item 33 ) -+e1412 // Reference member is not initialized -- [30, Item 4] --append( 1412, --- Eff. C++ 3rd Ed. item 4 ) -+e1413 // function is returning a temporary via a reference -- [30, Item 21] --append( 1413, --- Eff. C++ 3rd Ed. item 21 ) -+e1506 // Call to virtual function within a constructor or destructor -- [30, Item 9] --append( 1506, --- Eff. C++ 3rd Ed. item 9 ) -+e1509 // base class destructor for class is not virtual -- [12, Item 14], [30, Item 7] --append(1509, -- Effective C++ #14 & Eff. C++ 3rd Ed. item 7) -+e1510 // base class has no destructor -- [12, Item 14] --append(1510, -- Effective C++ #14 ) -+e1511 // Member hides non-virtual member -- [12, Item 37], [30, Item 33], [30, Item 36] --append(1511, -- Effective C++ #37 & Eff. C++ 3rd Ed. item 33& Eff. C++ 3rd Ed. item 36) -+e1516 // Data member hides inherited member -- [30, Item 33] --append( 1516, --- Eff. C++ 3rd Ed. item 33 ) -+e1529 // not first checking for assignment to this -- [12, Item 17], [30, Item 11] --append(1529, -- Effective C++ #17 & Eff. C++ 3rd Ed. item 11) -+e1531 // Symbol should have compared argument against sizeof(class) -- [30, Item 51] --append( 1531, --- Eff. C++ 3rd Ed. item 51 ) -+e1534 // static variable found within inline function -- [23, Item 26], [30, Item 30] --append(1534, -- More Effective C++ #26 & Eff. C++ 3rd Ed. item 30) -+e1536 // Exposing low access member -- [12, Item 30] --append(1536, -- Effective C++ #30 ) -+e1537 // const function returns pointer data member -- [12, Item 29 ], [30, Item 28] --append(1537, -- Effective C++ #29 & Eff. C++ 3rd Ed. item 28) -+e1539 // member not assigned by assignment operator -- [12, Item 16], [30, Item 12] --append(1539, -- Effective C++ #16 & Eff. C++ 3rd Ed. item 12) -+e1540 // pointer member freed nor zero'ed by destructor -- [12, Item 6] --append(1540, -- Effective C++ #6 ) -+e1541 // member possibly not initialized by constructor -- [30, Item 4], [30, Item 13] --append( 1541, --- Eff. C++ 3rd Ed. item 4 & Eff. C++ 3rd Ed. item 13) -+e1542 // member possibly not initialized -- [30, Item 4] --append( 1542, --- Eff. C++ 3rd Ed. item 4 ) -+e1543 // member possibly not initialized -- [30, Item 4] --append( 1543, --- Eff. C++ 3rd Ed. item 4 ) -+e1544 // value indeterminate (order of initialization) -- [12, Item 47] --append(1544, -- Effective C++ #47 ) -+e1546 // throw() called within destuctor -- [23, Item 11], [30, Item 8] --append(1546, -- Effective C++ #11 & Eff. C++ 3rd Ed. item 8) -+e1547 // Assignment of array to pointer to base -- [23, Item 3] --append(1547, -- More Effective C++ #3 ) -+e1549 // Exception thrown for function not declared to throw -- [23, Item 11] --append(1549, -- More Effective C++ #11 ) -+e1551 // function may throw an exception in destructor -- [23, Item 11], [30, Item 8] --append(1551, -- More Effective C++ #11 & Eff. C++ 3rd Ed. item 8) -+e1557 // const member is not initialized -- [30, Item 4] --append( 1557, --- Eff. C++ 3rd Ed. item 4 ) -+e1559 // Uncaught exception 'Name' may be thrown in destructor -- [30, Item 8] --append( 1559, --- Eff. C++ 3rd Ed. item 8 ) -+e1722 // assignment operator does not return a reference -- [12, Item 15], [30, Item 10] --append(1722, -- Effective C++ #15 & Eff. C++ 3rd Ed. item 10) -+e1724 // Argument to copy constructor for class should be a const reference -- [30, Item 3], [30, Item 20] --append( 1724, --- Eff. C++ 3rd Ed. item 3 & Eff. C++ 3rd Ed. item 20) -+e1727 // inline not previously defined inline at -- [30, Item 30] --append( 1727, --- Eff. C++ 3rd Ed. item 30 ) -+e1729 // Initializer inversion detected for member -- [12, Item 13] --append(1729, -- Effective C++ #13 ) -+e1732 // new in constructor for class which has no assignment operator -- [12, Item 11] --append(1732, -- Effective C++ #11 ) -+e1733 // new in constructor for class which has no copy constructor -- [12, Item 11] --append(1733, -- Effective C++ #11 ) -+e1735 // Virtual function has default parameter -- [12, Item 38] --append(1735, -- Effective C++ #38 ) -+e1737 // 'Symbol' hides global operator new -- [12, Item 9] --append(1737, -- Effective C++ #9 ) -+e1739 // Binary operator should be non-member function -- [12, Item 19], [30, Item 24] --append(1739, -- Effective C++ #19 & Eff. C++ 3rd Ed. item 24) -+e1740 // pointer member not directly freed or zero'ed by destructor -- [12, Item 6] --append(1740, -- Effective C++ #6 ) -+e1741 // member conceivably not initialized by constructor -- [30, Item 4], [30, Item 13] --append( 1741, --- Eff. C++ 3rd Ed. item 4 & Eff. C++ 3rd Ed. item 13) -+e1742 // member conceivably not initialized -- [30, Item 4] --append( 1742, --- Eff. C++ 3rd Ed. item 4 ) -+e1743 // member conceivably not initialized -- [30, Item 4] --append( 1743, --- Eff. C++ 3rd Ed. item 4 ) -+e1744 // member possibly not initialized by private constructor -- [30, Item 4] --append( 1744, --- Eff. C++ 3rd Ed. item 4 ) -+e1745 // member not assigned by private assignment operator -- [12, Item 16], [30, Item 12] --append(1745, -- Effective C++ #16 & Eff. C++ 3rd Ed. item 12) -+e1746 // parameter of function could be made const ref -- [12, Item 22], [30, Item 3], [30, Item 20] --append(1746, -- Effective C++ #22 & Eff. C++ 3rd Ed. item 3& Eff. C++ 3rd Ed. item 20) -+e1747 // binary operator returning a reference -- [12, Item 23] --append(1747, -- Effective C++ #23 ) -+e1749 // base class of class need not be virtual -- [23, Item 24] --append(1749, -- More Effective C++ #24 ) -+e1752 // catch parameter Integer is not a reference -- [23, Item 13] --append(1752, -- More Effective C++ #13 ) -+e1753 // Overloading special operator -- [23, Item 7] --append(1753, -- More Effective C++ #7 ) -+e1754 // Expected 'Symbol' to be declared for class 'Symbol' -- [23, Item 22] --append(1754, -- More Effective C++ #22 ) -+e1757 // Discarded instance of post decrement/increment -- [23, Item 6] --append(1757, -- More Effective C++ #6 ) -+e1758 // Prefix increment/decrement operator returns a non-reference. -- [23, Item 6] --append(1758, -- More Effective C++ #6 ) -+e1759 // Postfix increment/decrement operator returns a reference. -- [23, Item 6] --append(1759, -- More Effective C++ #6 ) -+e1762 // Member function could be made const -- [30, Item 3] --append( 1762, --- Eff. C++ 3rd Ed. item 3 ) -+e1764 // Reference parameter could be declared const reference -- [30, Item 3] --append( 1764, --- Eff. C++ 3rd Ed. item 3 ) -+e1770 // function defined without function 'String' -- [30, Item 52] --append( 1770, --- Eff. C++ 3rd Ed. item 52 ) -+e1772 // Assignment operator is not returning *this -- [30, Item 10] --append( 1772, --- Eff. C++ 3rd Ed. item 10 ) -+e1904 // Old-style C comment -- [12, Item 4] --append(1904, -- Effective C++ #4 ) -+e1921 // Symbol not checking argument against sizeof(class) -- [30, Item 51] --append( 1921, --- Eff. C++ 3rd Ed. item 51 ) -+e1923 // macro could become const variable -- [12, Item 1], [30, Item 2] --append(1923, -- Effective C++ #1 & Eff. C++ 3rd Ed. item 2) -+e1924 // C-style cast -- [23, Item 2] --append(1924, -- More Effective C++ #2 ) -+e1925 // public data member -- [12, Item 20], [30, Item 22] --append(1925, -- Effective C++ #20 & Eff. C++ 3rd Ed. item 22) -+e1926 // 'Symbol's default constructor implicitly called -- [12, Item 12] --append(1926, -- Effective C++ #12 ) -+e1927 // 'Symbol' was not initialized in the constructor init list -- [12, Item 12] --append(1927, -- Effective C++ #12 ) -+e1928 // 'Symbol' did not appear in the ctor initializer list -- [12, Item 12] --append(1928, -- Effective C++ #12 ) -+e1929 // function returning a reference -- [12, Item 23], [30, Item 21] --append(1929, -- Effective C++ #23 & Eff. C++ 3rd Ed. item 21) --esym( 1929, operator<<, operator>> ) // but these op's are OK -+e1930 // Conversion operator found -- [23, Item 5] --append(1930, -- More Effective C++ #5 ) -+e1931 // Constructor can be used for implicit conversions -- [23, Item 5] --append(1931, -- More Effective C++ #5 ) -+e1932 // Base class is not abstract. -- [23, Item 33] --append(1932, -- More Effective C++ #33 ) -+e1934 // flags member functions operator<< and operator>> --append(1934, -- Effective C++ #19 ) -+e1961 // virtual member function could be made const -- [30, Item 3] --append( 1961, --- Eff. C++ 3rd Ed. item 3 ) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.h b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.h deleted file mode 100644 index e948a20f..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.h +++ /dev/null @@ -1,35 +0,0 @@ -#ifndef CO_GCC_H_ -#define CO_GCC_H_ - -#ifdef _lint /* Make sure no compiler comes this way */ - -/* - The headers included below must be generated; For C++, generate - with: - - g++ [usual build options] -E -dM t.cpp >lint_cppmac.h - - For C, generate with: - - gcc [usual build options] -E -dM t.c >lint_cmac.h - - ...where "t.cpp" and "t.c" are empty source files. - - It's important to use the same compiler options used when compiling - project code because they can affect the existence and precise - definitions of certain predefined macros. See the preamble to - co-gcc.lnt for details and a tutorial. - */ -#if defined(__cplusplus) -//# include "lint_cppmac.h" -#else -# include "lint_cmac.h" -#endif - - -/* If the macros given by the generated macro files must be adjusted - in order for Lint to cope, then you can do so here. */ - - -#endif /* _lint */ -#endif /* CO_GCC_H_ */ diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.lnt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.lnt deleted file mode 100644 index f7bd38dd..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/co-gcc.lnt +++ /dev/null @@ -1,188 +0,0 @@ -/* co-gcc.lnt: This is the seed file for configuring Lint for use with - GCC versions 2.95.3 and later. - - Like all compiler options files this file is intended to be used - as follows: - - lint co-gcc.lnt source-files-to-be-linted - - Some of the information that co-gcc.lnt requires needs to be - furnished with the help of the gcc system itself. - - If any of these directions are unclear, you may gain a better insight - into what is happening by checking the file gcc-readme.txt - - For C, first create an empty file named empty.c and then - run the command (options are case sensitive): - - gcc -E -dM empty.c >lint_cmac.h - - This will capture macro definitions in a file that will be included - automatically at the beginning of each module by use of the -header - option within co-gcc.lnt. The macros may change as you change - compiler options so that ultimately you may want to incorporate - this step into a make facility. - - Next we need to determine the search directories. If you run - - gcc -c -v empty.c - - you will see among other things this coveted list. For example you - might get: - - ... - #include "..." search starts here - #include <...> search starts here - /usr/local/include - /usr/lib/gcc/i686-apple-darwin8/4.0.1/include - /usr/include - /System/Library/Frameworks - /Library/Frameworks - End of search list. - ... - - For each directory shown (there are five in the list above) prefix - the directory name by a "--i" and place it in a file whose name is, - say, include.lnt. You may then begin linting programs by using the - command - - lint co-gcc.lnt include.lnt source-files - - Note: it is conventional to place both .lnt files into a single .lnt - file called std.lnt - - For C++, run the command (options are again case sensitive): - - g++ -E -dM empty.c >lint_cppmac.h - - This will capture C++ macro definitions in a file that will be - included automatically at the beginning of each C++ module - at the request of co-gcc.lnt. - - Next we need to determine C++ search directories. If you run - - g++ -c -v empty.c - - As in the case of C you should prepend a --i onto each directory - displayed and place these options into a file such as include.lnt. - Again, there is nothing sacred about the name and if you intend to - do mixed C and C++ programming it will be necessary for you to use - a differently named file. The rest proceeds as before. - - Note, some options in this file (such as the size options, i.e. -sp4 - indicating that pointers are four bytes wide) may need to be changed. - See "System Dependent Options" below. -*/ - --cgnu // Notifies FlexeLint that gcc is being used. - -// Begin: System Dependent Options -// ------------------------------- --a#machine(i386) // #assert's machine(i386) (SVR4 facility). -+fdi // Use the directory of the including file --si4 // size of int --sp4 // size of pointer - -// ----------------------------- -// End: System Dependent Options - -+cpp(.cc,.c) // extensions for C++ that are commonly used in addition - // to the default extensions of .cpp and .cxx --header(scripts/pclint/co-gcc.h) // Includes header generated by GCC. -+libh(co-gcc.h) // Marks that header as library code. - -// ========================================================= -// +rw and -d options to cope with GNU syntax: -+ppw(ident) // Tolerate #ident keyword definitions for SCCS/RCS -+ppw(warning) - -// GCC provides alternative spellings of certain keywords: --rw_asgn(__inline,inline) --rw_asgn(__inline__,inline) --rw_asgn(__signed__,signed) --rw_asgn( __volatile__, volatile ) --rw_asgn( __volatile, volatile ) -++d__const=const // gconv.h uses __const rather than const -++dconst=const // ensure const expands to const. - --rw_asgn( asm, _up_to_brackets ) --rw_asgn( __asm, _up_to_brackets ) --rw_asgn( __asm__, _up_to_brackets ) -// This re-definition of the various spellings of the asm keyword enables -// Lint to pass gracefully over expression-statements like: -// __asm __volatile ("fsqrt" : "=t" (__result) : "0" (__x)); - -++d__attribute__()= // ignore this keyword and following parenthetical -++d__attribute()= // variant spelling of "__attribute__" - -// "__extension__" is GCC's way of allowing the use of non-standard -// constructs in a strict Standard-conforming mode. We don't currently -// have explicit support for it, but we can use local suppressions. For -// example, we can use -e(160) so that we will not see any Errors about -// GNU statement-expressions wrapped in __extension__(). -++d"__extension__=/*lint -e(160) */" - -++d__builtin_va_list=void* // used by stdarg.h -++d__builtin_stdarg_start()=_to_semi // ditto -++d__builtin_va_end()=_to_semi // ditto -++d"__builtin_va_arg(a,b)=(*( (b *) ( ((a) += sizeof(b)) - sizeof(b) )))" -++d__null=0 -+rw(_to_semi) // needed for the two macros above. -+rw(__typeof__) // activate __typeof__ keyword --d__typeof=__typeof__ // an alternative to using __typeof__ - -+rw( __restrict ) -+rw( __restrict__ ) --rw(__except) // This MS reserved word is used as an identifier -+rw( __complex__, __real__, __imag__ ) // reserved words that can be ignored. -++d__builtin_strchr=(char*) // permits the inline definition ... -++d__builtin_strpbrk=(char*) // of these functions to be linted ... -++d__builtin_strrchr=(char*) // without drawing a complaint -++d__builtin_strstr=(char*) // about the use of a non-standard name -++d__PRETTY_FUNCTION__=___function___ // lint defines ___function___ internally -++d__FUNCTION__=___function___ // lint defines ___function___ internally - - -// ========================================================= -// Other options supporting GNU C/C++ syntax: -+fld // enables the processing of _L_abel _D_esignators E.g.: - // union { double d; int i; } u = { d: 3.141 }; - -// +fwc // wchar_t might be builtin; if so, uncomment - // this option. - -// ========================================================= -// Generally useful suppressions: --wlib(1) // sets the warning level within library headers to 1 - // (no warnings, just syntax errors). Comment out if you - // are actually linting library headers. --elib(123) // 123 is really a warning, but it's in the "Error" range. --elib(93) // allow newlines within quoted string arguments to macros --elibsym(628) // Suppress 628 for __builtin symbols. - --esym(528,__huge_val,__nan,__qnan,__qnanf,__snan,__snanf) - // We don't care if we don't reference some GNU functions --esym(528,__gnu_malloc,__gnu_calloc) - -// The following functions exhibit variable return modes. -// That is, they may equally-usefully be called for a value -// as called just for their effects. Accordingly we inhibit -// Warning 534 for these functions. -// Feel free to add to or subtract from this list. - --esym(534,close,creat,fclose,fprintf,fputc, nanosleep, time) --esym(534,fputs,fscanf,fseek,fwrite,lseek,memcpy,memmove,memset) --esym(534,printf,puts,scanf,sprintf,sscanf,strcat,strcpy) --esym(534,strncat,strncpy,unlink,write, snprintf, dprintf) - -// For non-ANSI compilers we suppress messages 515 and 516 -// for functions known to have variable argument lists. -// For ANSI compilers, header files should take care of this. - --esym(515,fprintf,printf,sprintf,fscanf,scanf,sscanf) --esym(516,fprintf,printf,sprintf,fscanf,scanf,sscanf) --esym(1702,*operator<<,*operator>>) --esym(534,*operator<<,*operator>>) --esym(1055,*__builtin*) --esym(718,*__builtin*) // The compiler does not need these ... --esym(746,*__builtin*) // declared and it knows their prototypes. diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/lint_cfg.lnt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/lint_cfg.lnt deleted file mode 100644 index 72530d53..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/lint_cfg.lnt +++ /dev/null @@ -1,55 +0,0 @@ -// These settings are used to adjust the pcLint checking for -// the operating unit source code - -// show pclint where to find Header files --i".\include" --i".\lib" --i".\src" - --iC:\mingw\include --iC:\mingw\lib\gcc\mingw32\4.8.1\include\ --iC:\mingw\lib\gcc\mingw32\4.8.1\include\-fixed --iC:\mingw\lib\gcc\mingw32\4.8.1\include\c++\ --iC:\mingw\lib\gcc\mingw32\4.8.1\include\c++\mingw32 -//+libdir(D:\Programme\linaro\gcc-linaro-arm-linux-gnueabihf-4.9-2014.08\*) // define a directory as holding only headers, may be used with * or ? -//+libdir(D:\Programme\linaro\gcc-linaro-arm-linux-gnueabihf-4.9-2014.08\libc\usr\include\*) - -//+libclass(ansi) // use this if only ANSI headers are seen as unchecked libraries -+libclass(foreign) // ignore all headers comeing from a foreign directory using -i or the INCLUDE environment variable -//+libclass(angle) // ingore all headers specified with angle brackets -//+libclass(all) // ignore all header files -+libh(co-ggc.lnt) // ignore this file -//+libdir(uncrustify/scripts/*) -//-wlib(1) - -// Compiler specific configuration for Visual DSP - -// co-tiger.lnt use this file for tiger sharc as reference -scripts\pclint\co-gcc.lnt // Compiler Options for GCC - -// Configuration for checking the operating unit source code - -//-d__ARM_PCS_VFP --d__cplusplus --d_GNU_SOURCE -//-d__GNUC__ --d__STDC__ -//-d__GLIBCXX__=20130531 -//-d__SIZE_TYPE__=int -//-d__PTRDIFF_TYPE__=int -//-d__CHAR_BIT__=8 --dWIN32 --d__i386__ --dDEFINE_CHAR_TABLE --dDEFINE_PCF_NAMES - -// define compiler specific keywords - -//+rw(__inline) // activate the __inline keyword -//+ppw(import) // activate #import -//-d"_exit=_up_to_brackets" -//-d"extern 'C'=gobble" -//+fkp // complain about non-KR extensions - -// To print a stack usage report pclint has to know how much space is required by some functions -// define an upper limit of stack space usage for recursion and function pointers diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/pclint_cfg_eclipse.lnt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/pclint_cfg_eclipse.lnt deleted file mode 100644 index d1945c5b..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/pclint_cfg_eclipse.lnt +++ /dev/null @@ -1,58 +0,0 @@ -// These are generale configuration options used for pcLint -// throughout all kind of projects. -// This was adjusted to nuinno policy. -// See manual (chapter LIVING WITH LINT) for further details. -// -// Project specific settings shall be included from a separate file -// at the end of this file - -//-i"%PCLINT_HOME%" // add pclint home directory to include path - -//-p // only run preprocessor (use this for debugging pclint test) -//+source // print source code (use this for debugging pclint test) --v // be not verbose (standard setting for normal operation) -//-voif // show the options that pclint uses (only for debugging pclint) -//+v // be verbose (use this for debugging pclint test) -//-v* // be more verbose (use this for debugging pclint) -//-vf // print included files (useful for debugging pclint test) --summary // prints a summary of all pclint results (useful for debugging pclint test) -//-format_summary=. -//-format_template= -//-format_verbosity=. - -+fan // allow anonymous unions -++fim // use multiple include directories -+fus // automatically recognize std namespace -+fbo // activate keyword bool, true, false --fkp // allow ANSI/ISO standard do not insist on Kernighan Richy style --fdh // do not append a .h to header names --ffb // do not establish a separate scope for declares within for clauses -+fsv // track static variables -+fll // enable long long types -+fqb // expect const and volatile before type -+e900 // print total number of errors/warnings - --d__USE_GNU=1 -scripts\pclint\lint_cfg.lnt // include project specific settings -scripts\pclint\policy.lnt // pclint rules from nuinno - --esym(123,min,max) // allows users to use min, max as variables - -// Disable unwanted warnings -//-strong(AB,bool) -//-strong(AB,boolean) -//-strong(AJX) // all typedef must match exactly - -// create output that is understood from Jenkins -+ffn // force full path names --width(0) // don't insert line breaks (unlimited output width). --hF1 // set message height one -+program_info(output_prefix = "tests\pclint\pclint_") - -// make error format same as GCC to display it in Eclipse --"format=%(%f:%l:%C:%) %t %n: %m" --frl // Enable warning 831 -+flm // make sure no foreign includes change the format -// env-xml.lnt // create output in xml format -// -"format_stack=%-20f %5a %-20t %5n %c %e" -// +stack( &file=test\pclint\pclint-stack-report.txt ) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/policy.lnt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/policy.lnt deleted file mode 100644 index 911e74b7..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/policy.lnt +++ /dev/null @@ -1,396 +0,0 @@ -// uncrustify policy --passes(2) // number of analysis passes (higher values give better detection but slower) --static_depth(2) // number of analyzed redirection for static variables -//-w2 // suppress informational messages -// -strong(AJX) // All typedefs must match exactly --w3 // display informational messages -//-w4 // use the maximum warning level -//+fpn // warns about the use of pointer parameters without first checking for NULL -//+fsc // assumes string constants are const char* - -// all checks from 0 to 599 are enabled by +w2 --e10 // Expecting identifier or other declarator --e18 // symbol redefined --e19 // useless declaration --e14 // symbol previously defined --e26 // expected an expression found const/return --e30 // expected an integer constant --e31 // redefinition of symbol --e32 // field size should not be zero --e36 // redefining the storage class of symbol --e40 // undeclared identifier --e46 // field type should be an integral or enumeration type --e48 // bad type --e49 // expected a typed --e50 // attempted to take the address of a non-lvalue --e52 // expected an lvalue --e55 // bad type --e56 // bad type --e63 // expected an lvalue --e64 // type mismatch --e78 // typedef'd symbol used in expression --e85 // array has dimension 0 --e96 // unmatched left brace for linkage specification --e114 // inconsistent --e119 // too many arguments --e123 // macro defined with arguments --e129 // declaration expected --e200 // internal error --e438 // last value assignd to variable not used --e451 // header without include guard --e457 // enable for checking multithreading --e458 // enable for checking multithreading --e459 // enable for checking multithreading --e506 // allow constant value booleans --e514 // unusual use of boolean expression --e516 // symbol has arg type conflict --e520 // highest operation lacks side effects --e522 // highest operation lacks side effects --e526 // symbol not defined --e528 // symbol not referenced --e534 // ignoring return value of function --e537 // do not warn about repeated inclusion --e574 // signed / unsigned mix with relational --e578 // Declaration of symbol hides symbol --e585 // not a valid Trigraph sequence - -+e601 // Expected a type for symbol Symbol -+e602 // Comment within comment -+e603 // Symbol not initialized -+e604 // Returning address of auto variable -+e605 // Increase in pointer capability -+e606 // Non-ANSI escape sequence: -+e607 // Parameter of macro found within string -+e608 // Assigning to an array parameter -+e609 // Suspicious pointer conversion -+e610 // Suspicious pointer combination -+e611 // Suspicious cast -+e612 // Expected a declarator --e613 // Possible use of null pointer -+e614 // auto aggregate initializer not constant -+e615 // auto aggregate initializer has side effects -+e616 // control flows into case/default -+e617 // String is both a module and an include file -+e618 // Storage class specified after a type -+e619 // Loss of precision (Context) (Pointer to Pointer) -+e620 // Suspicious constant (small L or one?) -+e621 // Identifier clash -+e622 // Size of argument no. Integer inconsistent with format -+e623 // redefining the storage class of symbol -+e624 // typedef redeclared -+e625 // auto symbol has unusual type modifier -+e626 // Integer inconsistent with format -+e627 // indirect object inconsistent with format --e628 // no argument information provided for function -+e629 // static class for function is non standard -+e630 // ambiguous reference to symbol -+e631 // tag 'Symbol' defined differently at Location -+e632 // Assignment to strong type -+e633 // Assignment from a strong type -+e634 // Strong type mismatch in equality or conditional -+e635 // resetting strong parent of type -+e636 // ptr to strong type versus another type -+e637 // Expected index type for strong type -+e638 // Strong type mismatch for type in relational -+e639 // Strong type mismatch for type in binary operation -+e640 // Expected strong type 'Name' in Boolean context --e641 // Converting enum to int -+e642 // Format char 'Char' not supported by wsprintf -+e643 // Loss of precision in pointer cast -+e644 // Variable may not have been initialized -+e645 // Symbol may not have been initialized -+e646 // case/default within Kind loop; may have been misplaced -+e647 // Suspicious truncation -+e648 // Overflow in computing constant for operation: -+e649 // Sign fill during constant shift -+e650 // Constant out of range for operator -+e651 // Potentially confusing initializer --e652 // #define of symbol 'Symbol' declared previously -+e653 // Possible loss of fraction -+e654 // Option String obsolete; use -width(W,I) --e655 // bit-wise operation uses (compatible) enum's -+e656 // Arithmetic operation uses (compatible) enum's -+e657 // Unusual (nonportable) anonymous struct or union -+e658 // Anonymous union assumed -+e659 // Nothing follows '}' -+e660 // Option requests removing an extent that is not on the list -+e661 // possible access of out-of-bounds pointer -+e662 // possible creation of out-of-bounds pointer -+e663 // Suspicious array to pointer conversion -+e664 // Left side of logical OR (||) or logical AND (&&) does not return -+e665 // Unparenthesized parameter Integer in macro is passed an expression -+e666 // Expression with side effects passed to repeated parameter -+e667 // Inconsistent use of qualifiers for symbol -+e668 // Possibly passing a null pointer to function -+e669 // Possible data overrun for function -+e670 // Possible access beyond array for function -+e671 // Possibly passing to function a negative value -+e672 // Possible memory leak in assignment to pointer -+e673 // Possibly inappropriate deallocation -+e674 // Returning address of auto through variable -+e675 // No prior semantics associated with symbol -+e676 // Possibly negative subscript -+e677 // sizeof used within preprocessor statement -+e678 // Member field length (Integer) too small for enum precision -+e679 // Suspicious Truncation in arithmetic expression combining with pointer -+e680 // Suspicious Truncation in arithmetic expression converted to pointer -+e681 // Loop is not entered -+e682 // sizeof applied to a parameter whose type is a sized array -+e683 // function 'Symbol' #define'd -+e684 // Passing address of auto variable into caller space -+e685 // Relational operator always evaluates to same result -+e686 // Option is suspicious -+e687 // Suspicious use of comma operator -+e688 // Cast used within preprocessor conditional statement -+e689 // Apparent end of comment ignored -+e690 // Possible access of pointer pointing Integer bytes past null character by operator -+e691 // Suspicious use of backslash -+e692 // Decimal character follows octal escape sequence -+e693 // Hexadecimal digit immediately after is suspicious in string literal. -+e694 // The type of constant (precision Integer) is dialect dependent -+e695 // Inline function defined without a storage-class specifier ('static' recommended) -+e696 // Variable has value that is out of range for operator -+e697 // Quasi-boolean values should be equality-compared only with 0 -+e698 // Casual use of realloc can create a memory leak - -+e701 // Shift left of signed int variable --e702 // Shift right of signed int variable -+e703 // Shift left of signed long variable -+e704 // Shift right of signed long variable -+e705 // Integer nominally inconsistent with format -+e706 // indirect object inconsistent with format -+e707 // Mixing narrow and wide string literals in concatenation -+e708 // union initialization --e712 // Loss of precision --e713 // Loss of precision --e714 // external variable not referenced --e715 // Symbol not referenced --e716 // while(1) found, allow endless loops --e717 // do ... while(0) found -+e718 // Symbol undeclared, assumed to return int -+e719 // Too many arguments for format -+e720 // Boolean test of assignment -+e721 // Suspicious use of ; -+e722 // Suspicious use of ; -+e723 // Suspicious use of = -- A preprocessor definition began with an = sign. -+e725 // Expected positive indentation from Location --e726 // Extraneous comma ignored -+e727 // local static variable not explicitly initialized -+e728 // global static variable not explicitly initialized -+e729 // exteral variable not explicitly initialized --e730 // Boolean argument to function --e731 // Boolean argument to equal/not equal --e732 // Loss of sign -+e733 // Assigning address of auto variable to outer scope symbol -+e734 // Loss of precision int -+e735 // Loss of precision double -+e736 // Loss of precision float --e737 // Loss of sign in promotion from Type1 to Type2 -+e738 // Symbol not explicitly initialized -+e739 // Trigraph Sequence in literal (Quiet Change) -+e740 // Unusual pointer cast (incompatible indirect types) -+e741 // Unusual pointer cast (function qualification) -+e742 // Multiple character constant -+e743 // Negative character constant -+e744 // switch statement has no default -+e745 // function has no explicit type or class, int assumed -+e746 // call to function not made in the presence of a prototype --e747 // (noisy when using bool) Significant prototype coercion Type1 to Type2 -+e748 // Symbol is a register variable used with setjmp --e749 // check for unused enum values --e750 // ignore unused local macros --e751 // check for unused local typedefs --e752 // check for unused local declarations --e753 // check for unused local struct, union or enum tag --e754 // check for unused local structure member --e755 // ignore unused global macros --e756 // check for unused global typedefs --e757 // check for unused global declarations --e758 // check for unused global struct, union or enum tag --e759 // check if symbol can be moved from header to module -+e760 // check for redundant macros --e761 // check for redundant typedefs -+e762 // check for redundantly declared symbol -+e763 // check for redundant declaration for symbol -+e764 // check for switch statement without a case --e765 // check for external symbols that could be made static -+e766 // check for unused headers -+e767 // check for differing macros --e768 // check for global struct member that is never referenced --e769 // check for global enumeration constant that is never referenced -+e770 // tag is defined identically at several locations -+e771 // check for uninitialized symbols -+e772 // check for uninitialized symbols -+e773 // Expression-like macro not parenthesized --e774 // Boolean within 'String' always evaluates to [True/False] -+e775 // non-negative quantity cannot be less than zero -+e776 // Possible truncation of addition -+e777 // Testing float's for equality --e778 // Constant expression evaluates to 0 -+e779 // String constant in comparison operator -+e780 // Vacuous array element -+e782 // Line exceeds Integer characters -+e783 // Line does not end with new-line -+e784 // Nul character truncated from string -+e785 // Too few initializers for aggregate -+e786 // String concatenation within initializer -+e787 // enum constant should not be used within switch --e788 // enum constant not used within defaulted switch -+e789 // Assigning address of auto variable to static -+e790 // Suspicious truncation, integral to float -+e791 // unusual option sequence -+e792 // void cast of void expression -+e793 // ANSI/ISO limit of String 'Name' exceeded -+e794 // Conceivable use of null pointer -+e795 // Conceivable division by 0 -+e796 // Conceivable access of out-of-bounds pointer -+e797 // Conceivable creation of out-of-bounds pointer -+e798 // Redundant character -+e799 // numerical constant 'Integer' larger than unsigned long - --e801 // Use of goto is deprecated -+e802 // Conceivably passing a null pointer to function -+e803 // Conceivable data overrun for function -+e804 // Conceivable access beyond array for function -+e805 // Expected L"..." to initialize wide char string -+e806 // Small bit field is signed rather than unsigned -+e807 // Conceivably passing to function a negative value -+e808 // No explicit type given to symbol -+e809 // Possible return of address of auto through variable -+e810 // Arithmetic modification of custodial variable -+e811 // Possible deallocation of pointer alias -+e812 // static variable 'Symbol' has size 'Integer' -+e813 // auto variable 'Symbol' in function 'Symbol' has size 'Integer' -+e814 // useless declaration -+e815 // Arithmetic modification of unsaved pointer -+e816 // Non-ANSI format specification -+e817 // Conceivably negative subscript --e818 // Pointer parameter could be declared ptr to const -+e820 // Boolean test of a parenthesized assignment -+e821 // Right hand side of assignment not parenthesized -+e825 // control flows into case/default without -fallthrough comment -+e826 // Suspicious pointer-to-pointer conversion -+e827 // Loop not reachable -+e828 // redefinition of functions -+e829 // dangerous header was used -+e830 // print error location indicator -+e831 // print error location indicator -+e832 // Parameter 'Symbol' not explicitly declared -+e833 // Symbol is typed differently in another module --e834 // missing parentheses between operators --e835 // A zero has been given as [left/right] argument to operator -+e836 // Conceivable access of pointer pointing Integer bytes past nul -+e838 // Previously assigned value to variable has not been used -+e839 // Storage class of symbol 'Symbol' assumed static -+e840 // Use of null character in a string literal --e843 // Variable 'Symbol' (Location) could be declared as const -+e844 // Pointer variable could be declared as pointing to const --e845 // The [left/right] argument to operator is certain to be 0 -+e846 // Signedness of bit-field is implementation defined -+e847 // Thread has unprotected call to thread unsafe function -+e849 // Two enumerators have the same value --e850 // loop index variable is modified in body of the for loop --e864 // Expression possibly depends on order of evaluation -+e866 // Unusual use of 'String' in argument to sizeof - -+e900 // print total number of errors/warnings --e904 // Return statement before end of function 'Symbol' -+e905 // Non-literal format specifier used (with arguments) --e909 // Implicit conversion from Type to bool --e910 // Implicit conversion (Context) from 0 to pointer --e911 // (noisy) Implicit expression promotion from Type to Type --e912 // (noisy) Implicit binary conversion from Type1 to Type2 -+e913 // Implicit adjustment of expected argument type from Type1 to Type2 -+e914 // Implicit adjustment of function return value from Type1 to Type2 --e915 // (noisy) Implicit conversion (Context) Type1 to Type2 --e916 // Implicit pointer assignment conversion --e917 // (noisy) Prototype coercion Type1 to Type2 --e918 // Prototype coercion (Context) of pointers --e919 // (noisy) Implicit conversion (Context) Type to Type --e920 // Cast from Type to void --e931 // Both sides have side effects -+e932 // Passing near pointer to library function 'Symbol' -+e933 // Passing near pointer to far function (Context) -+e934 // taking address of near auto variable 'Symbol' --e935 // (noisy) int within struct -+e936 // type is missing for function arguments -+e937 // type is missing for function arguments -+e939 // return type is missing for function -+e940 // omitted braces within an initialize -+e943 // Too few initializers for aggregate -+e945 // Undefined struct used with extern --e946 // Relational or subtract operator applied to pointers -+e947 // Subtract operator applied to pointers --e950 // Non-ISO/ANSI reserved word or construct: -+e951 // Pointer to incomplete type employed in operation --e952 // Parameter could be declared const --e953 // Variable could be declared as const --e954 // Pointer variable could be declared as pointing to a const -+e955 // Parameter name missing from prototype for function --e956 // (use for multithreaded SW) Non const, non volatile static or external variable -+e957 // Function defined without a prototype in scope --e958 // (can help to save some bytes of memory) Padding of Integer byte(s) is required to align string on Integer byte boundary -+e962 // Macro defined identically at another location -+e963 // expect modifier (const, volatile) before type --e964 // Header file not directly used in module --e966 // Indirectly included header file 'FileName' not used in module -+e967 // Header file 'FileName' does not have a standard include guard --e970 // (noisy) Use of modifier or type outside of a typedef --e971 // (noisy) Use of 'char' without 'signed' or 'unsigned' -+e974 // print Worst case function for stack usage: --e1013 // symbol is not a member of class --e1015 // symbol not found in class --e1025 // no function or template matches invocation --e1039 // symbol is not a member of class --e1040 // symbol is not a legal declaration within class --e1042 // a least one class like operand is required with operator --e1048 // expected a constant expression --e1051 // symbol is both a function and a variable --e1052 // a type was expected, class assumed --e1054 // template variable declaration expects a type --e1055 // symbol undeclared, assumed to return int --e1057 // member cannot be used without an object --e1058 // initializing a non-const reference --e1065 // symbol not declared as "C" --e1062 // template must be either a class or a function --e1066 // symbol declared as "C" --e1075 // Ambiguous reference to symbol --e1077 // could not evaluate default template parameter --e1086 // do not warn about compount literals --e1087 // previous declaration is incompatible --e1401 // member not initialized by constructor --e1502 // object has no nonstatic data member --e1526 // Member function not defined --e1529 // symbol not first checking for assignment to this --e1536 // exposing low access member --e1540 // pointer member neither freed nor zeroed by destructor --e1551 // function may throw exception in destructor --e1554 // direct pointer copy of member within copy constructor --e1561 // reference initialization causes loss of const/volatile --e1566 // member might have been initialized by a separate function --e1702 // operator is both an ordinary function and a member function --e1704 // constructor has private access specification --e1711 // function needs not to be virtual --e1712 // default constructor not defined for class --e1714 // Member function not referenced --e1725 // class member is a reference --e1732 // constructor for class has no assignment operator --e1733 // constructor for class has no copy constructor --e1736 // redundant access specifier --e1740 // pointer member not directly freed or zeroed by destructor --e1746 // parameter could be made const reference --e1757 // discarded instance of post decrement/increment --e1762 // member could be made const --e1764 // reference parameter could be declared const --e1776 // converting a string literal to char* --e1786 // implicit conversion to bool --e1788 // variable is referenced only by its constructor or destructor --e1795 // Template was defined but not instantiated --e1904 // allow old style comments --e1923 // ignore defines that could be const variables --e1924 // C-style cast - -//scripts/pclint/au-sm123.lnt // also check Scott Meyers rules of all three books -//scripts/pclint/au-misra3.lnt // Misra 2012 rules -//scripts/pclint/au-barr10.lnt // Top 10 Bug-Killing Rules -//scripts/pclint/au-ds.lnt // Dan Saks diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/run-pclint-eclipse.bat b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/run-pclint-eclipse.bat deleted file mode 100644 index 051813d6..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/run-pclint-eclipse.bat +++ /dev/null @@ -1,104 +0,0 @@ -rem set to on for debugging -@echo off -setlocal - -rem Run this script from the project root directory - -echo ------------------------------------------------------ -echo Start pcLint analysis to check code quality ... - -set SRC_DIR=src -set EXC_DIR=lnt -set OUT_DIR=tests\pclint -set LNT_DIR=scripts\pclint - -rem Check if pcLint program is available -set prog=lint-nt.exe -for %%i in ("%path:;=";"%") do ( -rem echo %%~i - if exist %%~i\%prog% ( - set found=%%i - echo found %prog% in %%i - ) -) -if %found%=="" goto PROG_MISSING - -if NOT EXIST tests md tests -if NOT EXIST tests\pclint md tests\pclint - -rem create list of all C source files to analyze -rem FIXME: works only if there are no spaces in the paths - -dir /s/b %EXC_DIR%\*.lnt > .\%OUT_DIR%\exceptions.lnt - -rem to check single files activate one of the lines below -rem dir /s/b %SRC_DIR%\align_stack.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\align.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\args.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\backup.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\brace_cleanup.cpp> .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\braces.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\chunk.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\ChunkStack.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\combine.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\compat_posix.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\compat_win32.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\defines.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\detect.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\indent.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\keywords.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\lang_pawn.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\logger.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\logmask.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\md5.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\newlines.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\options_for_QT.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\options.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\output.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\parens.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\parse_frame.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\punctuators.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\semicolons.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\sorting.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\space.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\tokenize_cleanup.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\tokenize.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\unc_text.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\unc_tools.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\uncrustify_emscripten.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\uncrustify.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\unicode.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\universalindentgui.cpp > .\%OUT_DIR%\files.lnt -rem dir /s/b %SRC_DIR%\width.cpp > .\%OUT_DIR%\files.lnt - -rem to check all source files use the line below -dir /s/b %SRC_DIR%\*.cpp > .\%OUT_DIR%\files.lnt - -rem use this to save the pclint errors to a file for later review -rem lint-nt .\%LNT_DIR%\pclint_cfg_eclipse.lnt .\%OUT_DIR%\exceptions.lnt .\%OUT_DIR%\files.lnt > .\%OUT_DIR%\pclint-results.xml - -rem to make eclipse parse the pclint errors it has to be output to the console -lint-nt .\%LNT_DIR%\pclint_cfg_eclipse.lnt .\%OUT_DIR%\exceptions.lnt .\%OUT_DIR%\files.lnt - -rem type %OUT_DIR%\pclint-results.xml | more -rem type %OUT_DIR%\pclint-results.xml -rem echo pcLint output placed in %OUT_DIR%\pclint-results.xml - -goto END - -:PROG_MISSING -echo. -echo ------------------------------------------------------ -echo pcLint Error: %prog% not found. -echo Verify that PCLINT is correctly installed, the -echo installation was added to the PATH and the -echo environment variable PCLINT_HOME was set to its path. -echo ------------------------------------------------------ -echo. -goto END - -:END -echo pcLint finished -echo ------------------------------------------------------ -endlocal - diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/usage.txt b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/usage.txt deleted file mode 100644 index fff1c305..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/pclint/usage.txt +++ /dev/null @@ -1,16 +0,0 @@ -"pclint" is a static source code checker. -It helps detecting programming errors during development. - -To run the check you need a license for pclint. The results can either be saved to a text file or be displayed on top of the source code when using Eclipse. -The present configuration is ment for Windows using Mingw as toolchain. To run the check with another toolchain the paths in run-pclint-eclipse.bat need to be change. To run the check under Linux another tool called "flexelint" is required. - -Run the check from the top level directory of uncrustify by calling -run-pclint-eclipse.bat - -To run the check from Eclipse create a new target and use the script -as build command like that: -${workspace_loc:/uncrustify}/scripts/pclint/run-pclint-eclipse.bat - -The file policy.lnt determines which tests are performed. -The more tests are used the longer it takes but the more -precise will be the results.
\ No newline at end of file diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/prepare_list_of_authors.sh b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/prepare_list_of_authors.sh deleted file mode 100755 index 6485d377..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/prepare_list_of_authors.sh +++ /dev/null @@ -1,43 +0,0 @@ -#! /bin/sh -# -# Prepare the list of authors -# guy maurel -# 2020-11-05 -# -LIST_1="TheListOfAuthors.txt" -echo "Author:" > ${LIST_1} -echo "2005 - 2016 : Ben Gardner" >> ${LIST_1} -echo "" >> ${LIST_1} -echo "Maintenance:" >> ${LIST_1} -echo "Guy Maurel" >> ${LIST_1} -echo "Matthew Woehlke" >> ${LIST_1} -echo "" >> ${LIST_1} -echo "until 2020-11-05:" >> ${LIST_1} -echo "Other collaborators:" >> ${LIST_1} -git log --format='%aN' \ - | sort -u \ - | grep -v "^ben$" \ - | grep -v "^bengardner$" \ - | grep -v "^Ben Gardner$" \ - | grep -v "^CDanU$" \ - | grep -v "^DVE2000$" \ - | grep -v "^Gilles$" \ - | grep -v "^Guy Maurel$" \ - | grep -v "^brmqk3$" \ - | grep -v "^csobeski$" \ - | grep -v "^dbeard$" \ - | grep -v "^gmaurel$" \ - | grep -v "^hdwobben$" \ - | grep -v "^ipaterson$" \ - | grep -v "^jlee975$" \ - | grep -v "^logan.gauthier@metova.com$" \ - | grep -v "^nivekkagicom$" \ - | grep -v "^popipo$" \ - | grep -v "^raefaldhia$" \ - | grep -v "^rdan$" \ - | grep -v "^tpltnt$" \ - | grep -v "^versusvoid$" \ - | grep -v "^void$" \ - >> ${LIST_1} -# -mv ${LIST_1} AUTHORS diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/release_tool.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/release_tool.py deleted file mode 100755 index 2dd71676..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/release_tool.py +++ /dev/null @@ -1,247 +0,0 @@ -#!/usr/bin/env python - -import argparse -import git -import os -import re -import sys - -if sys.version_info[0] < 3: - input = raw_input - -re_desc = re.compile(r'^uncrustify-([0-9]+[.][0-9]+[.][0-9]+)') -re_branch = re.compile(r'^uncrustify-RC-([0-9]+[.][0-9]+[.][0-9]+)') -re_merge = re.compile(r'^Merge pull request #[0-9]+ from [^/]+/(.*)') -re_version = re.compile(r'^[0-9]+[.][0-9]+[.][0-9]+$') -re_option_count = re.compile(r'There are currently ([0-9]+) options') - - -# ----------------------------------------------------------------------------- -def fatal(msg): - raise Exception(msg) - - -# ----------------------------------------------------------------------------- -def get_version_str(repo, candidate=True, required=True): - if candidate: - b = repo.git.symbolic_ref('-q', '--short', 'HEAD') - m = re_branch.match(b) - if m: - return m.group(1) - - d = repo.git.describe('HEAD') - m = re_desc.match(d) - if m: - return m.group(1) - - if required: - fatal('Unable to determine current version') - - return None - - -# ----------------------------------------------------------------------------- -def get_version_info(repo, candidate=True, required=True): - s = get_version_str(repo, candidate, required) - return tuple(map(int, s.split('.'))) - - -# ----------------------------------------------------------------------------- -def get_option_count(executable): - import subprocess - - out = subprocess.check_output([executable, '--count-options']) - m = re_option_count.match(out.decode('utf-8')) - if m is None: - fatal('Failed to get option count from \'{}\''.format(executable)) - - return int(m.group(1)) - - -# ----------------------------------------------------------------------------- -def alter(repo, path, old, new): - p = os.path.join(repo.working_tree_dir, path) - with open(p, 'r') as f: - content = f.read() - content = re.sub(old, new, content) - with open(p, 'w') as f: - f.write(content) - print('Updated: {}'.format(path)) - - -# ----------------------------------------------------------------------------- -def generate(repo, version, path, *args): - import subprocess - - p = os.path.join(repo.working_tree_dir, path) - with open(p, 'w') as f: - c = subprocess.check_call(args, stdout=f) - print('Created: {}'.format(path)) - - alter(repo, path, - r'Uncrustify-[0-9.]+(-[0-9]+-[0-9a-f]+(-dirty)?)?', - r'Uncrustify-{}'.format(version)) - - -# ----------------------------------------------------------------------------- -def cmd_init(repo, args): - v = args.version - if v is None: - c = get_version_info(repo, candidate=False, required=False) - if c: - n = '.'.join(map(str, (c[0], c[1] + 1, 0))) - v = input('Version to be created? [{}] '.format(n)) - if len(v) == 0: - v = n - - else: - v = input('Version to be created? ') - - if not re_version.match(v): - fatal('Bad version number, \'{}\''.format(v)) - - repo.git.checkout('-b', 'uncrustify-RC-{}'.format(v)) - - -# ----------------------------------------------------------------------------- -def cmd_update(repo, args): - v = get_version_str(repo) - c = get_option_count(args.executable) - - alter(repo, 'CMakeLists.txt', - r'(set *[(] *UNCRUSTIFY_VERSION +")[0-9.]+', - r'\g<1>{}'.format(v)) - alter(repo, 'package.json', - r'("version" *): *"[0-9.]+"', - r'\g<1>: "{}"'.format(v)) - alter(repo, 'README.md', - r'[0-9]+ configurable options as of version [0-9.]+', - r'{} configurable options as of version {}'.format(c, v)) - alter(repo, 'documentation/htdocs/index.html', - r'[0-9]+ configurable options as of version [0-9.]+', - r'{} configurable options as of version {}'.format(c, v)) - - generate(repo, v, 'etc/defaults.cfg', - args.executable, '--show-config') - generate(repo, v, 'documentation/htdocs/default.cfg', - args.executable, '--show-config') - generate(repo, v, 'documentation/htdocs/config.txt', - args.executable, '--show-config') - generate(repo, v, 'etc/uigui_uncrustify.ini', - args.executable, '--universalindent') - - -# ----------------------------------------------------------------------------- -def cmd_commit(repo, args): - v = get_version_str(repo) - message = 'Prepare Uncrustify v{} release'.format(v) - - extra_args = [] - if args.amend: - extra_args += ['--amend', '--date=now'] - - repo.git.commit('-m', message, *extra_args) - - -# ----------------------------------------------------------------------------- -def cmd_tag(repo, args): - import uuid - - # Determine location of remote repository - if args.ssh: - s = 'git@{}:'.format(args.server) - else: - s = 'https://{}/'.format(args.server) - r = '{}{}/{}.git'.format(s, args.organization, args.project) - - # Fetch upstream - u = repo.create_remote(str(uuid.uuid4()), r) - try: - u.fetch(refspec='master') - - # Get log - if hasattr(args, 'commit'): - c = repo.commit(args.commit) - else: - c = repo.commit('{}/master'.format(u.name)) - m = re_merge.match(c.message.split('\n')[0]) - if m is None: - fatal('Last commit is not a merge of a release candidate?') - - m = re_branch.match(m.group(1)) - if m is None: - fatal('Failed to extract version from release candidate merge') - v = m.group(1) - - # Create and push tag - extra_args = {} - if args.force: - extra_args['force_with_lease'] = True - - tag = 'uncrustify-{}'.format(v) - message = 'Create Uncrustify v{} release'.format(v) - repo.git.tag('-a', tag, c, '-m', message, '--force') - u.push(refspec=tag, **extra_args) - - finally: - repo.delete_remote(u) - - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser( - description='Perform release-related actions') - - root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..')) - parser.add_argument('--repo', type=str, default=root, - help='path to uncrustify git repository') - - subparsers = parser.add_subparsers(title='subcommands', - help='action to perform') - - parser_init = subparsers.add_parser( - 'init', help='initialize new version') - parser_init.set_defaults(func=cmd_init) - parser_init.add_argument('-v', '--version', - help='version number for release') - - parser_update = subparsers.add_parser( - 'update', help='update version information') - parser_update.set_defaults(func=cmd_update) - parser_update.add_argument('executable', - help='path to uncrustify executable') - - parser_commit = subparsers.add_parser( - 'commit', help='commit changes for new version') - parser_commit.set_defaults(func=cmd_commit) - parser_commit.add_argument('-a', '--amend', action='store_true', - help='amend a previous release commit') - - parser_tag = subparsers.add_parser( - 'tag', help='tag release and push tag to github') - parser_tag.set_defaults(func=cmd_tag) - parser_tag.add_argument('--ssh', action='store_true', - help='use ssh (instead of HTTPS) to push') - parser_tag.add_argument('-s', '--server', default='github.com', - help='push to specified server') - parser_tag.add_argument('-o', '--organization', default='uncrustify', - help='push to specified user or organization') - parser_tag.add_argument('-p', '--project', default='uncrustify', - help='push to specified project') - parser_tag.add_argument('-c', '--commit', - help='tag specified commit ' - '(instead of latest \'master\')') - parser_tag.add_argument('-f', '--force', action='store_true', - help='force push the tag') - - args = parser.parse_args() - repo = git.Repo(args.repo) - args.func(repo, args) - - return 0 - - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -if __name__ == '__main__': - sys.exit(main()) diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/run_ctest.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/run_ctest.py deleted file mode 100755 index 0267e0ad..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/run_ctest.py +++ /dev/null @@ -1,43 +0,0 @@ -#!/usr/bin/env python - -import argparse -import math -import os -import subprocess -import sys - -from multiprocessing import cpu_count - -default_jobs = min(cpu_count() + 2, cpu_count() * 2) - -# ----------------------------------------------------------------------------- -def main(): - parser = argparse.ArgumentParser(description='Run CTest') - parser.add_argument('-q', '--quiet', action='store_true', - help='suppress output of failing tests') - parser.add_argument('-j', '--parallel', type=int, default=default_jobs, - help='number of jobs to use for parallel execution') - parser.add_argument('args', metavar='ARGS', nargs='*', default=[], - help='additional arguments to pass to CTest') - args = parser.parse_args() - - if not os.path.exists('CTestTestfile.cmake'): - print('No test configuration file found!') - print('(Note: This script must be run from your build directory.)') - sys.exit(-1) - - cmd = ['ctest', '-j{}'.format(args.parallel)] - if not args.quiet: - cmd.append('--output-on-failure') - cmd += args.args - - try: - subprocess.check_call(cmd) - except subprocess.CalledProcessError as exc: - sys.exit(exc.returncode) - - -# %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -if __name__ == '__main__': - main() diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/tokenizer.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/tokenizer.py deleted file mode 100755 index 0bc33bac..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/tokenizer.py +++ /dev/null @@ -1,316 +0,0 @@ -#! /usr/bin/env python -# tokenize.py -# -# Parses a C/C++/C#/D/Java/Pawn/whatever file in an array of -# tuples (string, type) -# - -# punctuator lookup table -punc_table = [ - [ '!', 25, 26, '!' ], # 0: '!' - [ '#', 24, 35, '#' ], # 1: '#' - [ '$', 23, 0, '$' ], # 2: '$' - [ '%', 22, 36, '%' ], # 3: '%' - [ '&', 21, 41, '&' ], # 4: '&' - [ '(', 20, 0, '(' ], # 5: '(' - [ ')', 19, 0, ')' ], # 6: ')' - [ '*', 18, 43, '*' ], # 7: '*' - [ '+', 17, 44, '+' ], # 8: '+' - [ ',', 16, 0, ',' ], # 9: ',' - [ '-', 15, 46, '-' ], # 10: '-' - [ '.', 14, 50, '.' ], # 11: '.' - [ '/', 13, 53, '/' ], # 12: '/' - [ ':', 12, 54, ':' ], # 13: ':' - [ ';', 11, 0, ';' ], # 14: ';' - [ '<', 10, 56, '<' ], # 15: '<' - [ '=', 9, 63, '=' ], # 16: '=' - [ '>', 8, 65, '>' ], # 17: '>' - [ '?', 7, 0, '?' ], # 18: '?' - [ '[', 6, 70, '[' ], # 19: '[' - [ ']', 5, 0, ']' ], # 20: ']' - [ '^', 4, 71, '^' ], # 21: '^' - [ '{', 3, 0, '{' ], # 22: '{' - [ '|', 2, 72, '|' ], # 23: '|' - [ '}', 1, 0, '}' ], # 24: '}' - [ '~', 0, 74, '~' ], # 25: '~' - [ '<', 3, 30, '!<' ], # 26: '!<' - [ '=', 2, 33, '!=' ], # 27: '!=' - [ '>', 1, 34, '!>' ], # 28: '!>' - [ '~', 0, 0, '!~' ], # 29: '!~' - [ '=', 1, 0, '!<=' ], # 30: '!<=' - [ '>', 0, 32, '!<>' ], # 31: '!<>' - [ '=', 0, 0, '!<>='], # 32: '!<>=' - [ '=', 0, 0, '!==' ], # 33: '!==' - [ '=', 0, 0, '!>=' ], # 34: '!>=' - [ '#', 0, 0, '##' ], # 35: '##' - [ ':', 2, 39, '%:' ], # 36: '%:' - [ '=', 1, 0, '%=' ], # 37: '%=' - [ '>', 0, 0, '%>' ], # 38: '%>' - [ '%', 0, 40, None ], # 39: '%:%' - [ ':', 0, 0, '%:%:'], # 40: '%:%:' - [ '&', 1, 0, '&&' ], # 41: '&&' - [ '=', 0, 0, '&=' ], # 42: '&=' - [ '=', 0, 0, '*=' ], # 43: '*=' - [ '+', 1, 0, '++' ], # 44: '++' - [ '=', 0, 0, '+=' ], # 45: '+=' - [ '-', 2, 0, '--' ], # 46: '--' - [ '=', 1, 0, '-=' ], # 47: '-=' - [ '>', 0, 49, '->' ], # 48: '->' - [ '*', 0, 0, '->*' ], # 49: '->*' - [ '*', 1, 0, '.*' ], # 50: '.*' - [ '.', 0, 52, '..' ], # 51: '..' - [ '.', 0, 0, '...' ], # 52: '...' - [ '=', 0, 0, '/=' ], # 53: '/=' - [ ':', 1, 0, '::' ], # 54: '::' - [ '>', 0, 0, ':>' ], # 55: ':>' - [ '%', 4, 0, '<%' ], # 56: '<%' - [ ':', 3, 0, '<:' ], # 57: '<:' - [ '<', 2, 61, '<<' ], # 58: '<<' - [ '=', 1, 0, '<=' ], # 59: '<=' - [ '>', 0, 62, '<>' ], # 60: '<>' - [ '=', 0, 0, '<<=' ], # 61: '<<=' - [ '=', 0, 0, '<>=' ], # 62: '<>=' - [ '=', 0, 64, '==' ], # 63: '==' - [ '=', 0, 0, '===' ], # 64: '===' - [ '=', 1, 0, '>=' ], # 65: '>=' - [ '>', 0, 67, '>>' ], # 66: '>>' - [ '=', 1, 0, '>>=' ], # 67: '>>=' - [ '>', 0, 69, '>>>' ], # 68: '>>>' - [ '=', 0, 0, '>>>='], # 69: '>>>=' - [ ']', 0, 0, '[]' ], # 70: '[]' - [ '=', 0, 0, '^=' ], # 71: '^=' - [ '=', 1, 0, '|=' ], # 72: '|=' - [ '|', 0, 0, '||' ], # 73: '||' - [ '=', 1, 0, '~=' ], # 74: '~=' - [ '~', 0, 0, '~~' ], # 75: '~~' -] - - -# -# Token types: -# 0 = newline -# 1 = punctuator -# 2 = integer -# 3 = float -# 4 = string -# 5 = identifier -# -class Tokenizer: - def __init__(self): - self.tokens = [] - self.text = '' - self.text_idx = 0 - - def tokenize_text(self, in_text): - self.tokens = [] - self.text = in_text - self.text_idx = 0 - - print(in_text) - try: - while self.text_idx < len(self.text): - if self.parse_whitespace(): - continue - elif self.text[self.text_idx] == '\\' and self.text[self.text_idx + 1] == '\n': - self.text_idx += 2 - continue - elif self.parse_comment(): - continue - elif self.parse_number(): - continue - elif self.parse_identifier(): - continue - elif self.parse_string(): - continue - elif self.parse_punctuator(): - continue - else: - print("confused: %s" % self.text[self.text_idx:]) - break - except: - print("bombed") - raise - - def parse_whitespace(self): - start_idx = self.text_idx - hit_newline = False - while self.text_idx < len(self.text): - if self.text[self.text_idx] in '\n\r': - hit_newline = True - elif not self.text[self.text_idx] in ' \t': - break - self.text_idx += 1 - - if hit_newline: - self.tokens.append(('\n', 0)) - return start_idx != self.text_idx - - def parse_comment(self): - if not self.text[self.text_idx] == '/' or not self.text[self.text_idx + 1] in '/*': - return False - if self.text[self.text_idx + 1] == '/': - while self.text_idx < len(self.text): - if self.text[self.text_idx] in '\n\r': - break - self.text_idx += 1 - else: - while self.text_idx < len(self.text) - 1: - if self.text[self.text_idx] == '*' and self.text[self.text_idx + 1] == '/': - self.text_idx += 2 - break - self.text_idx += 1 - return True - - def parse_identifier(self): - if not self.text[self.text_idx].upper() in '@_ABCDEFGHIJKLMNOPQRSTUVWXYZ': - return False - start_idx = self.text_idx - while self.text_idx < len(self.text) and \ - self.text[self.text_idx].upper() in '@_ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890': - self.text_idx += 1 - self.tokens.append((self.text[start_idx : self.text_idx], 5)) - return True - - def parse_string(self): - starter = 0 - start_ch = self.text[self.text_idx] - if start_ch == 'L': - starter = 1 - start_ch = self.text[self.text_idx + 1] - if not start_ch in '"\'': - return False - start_idx = self.text_idx - self.text_idx += starter + 1 - escaped = False - while self.text_idx < len(self.text): - if escaped: - escaped = False - else: - if self.text[self.text_idx] == '\\': - escaped = True - elif self.text[self.text_idx] == start_ch: - self.text_idx += 1 - break - self.text_idx += 1 - - self.tokens.append((self.text[start_idx : self.text_idx], 4)) - return True - - # Checks for punctuators - # Returns whether a punctuator was consumed (True or False) - def parse_punctuator(self): - tab_idx = 0 - punc_len = 0 - saved_punc = None - while 1: - pte = punc_table[tab_idx] - if pte[0] == self.text[self.text_idx]: - if pte[3] is not None: - saved_punc = pte[3] - self.text_idx += 1 - tab_idx = pte[2] - if tab_idx == 0: - break - elif pte[1] == 0: - break - else: - tab_idx += 1 - if saved_punc is not None: - self.tokens.append((saved_punc, 1)) - return True - return False - - def parse_number(self): - # A number must start with a digit or a dot followed by a digit - ch = self.text[self.text_idx] - if not ch.isdigit() and (ch != '.' or not self.text[self.text_idx + 1].isdigit()): - return False - token_type = 2 # integer - if ch == '.': - token_type = 3 # float - did_hex = False - start_idx = self.text_idx - - # Check for Hex, Octal, or Binary - # Note that only D and Pawn support binary, but who cares? - # - if ch == '0': - self.text_idx += 1 - ch = self.text[self.text_idx].upper() - if ch == 'X': # hex - did_hex = True - self.text_idx += 1 - while self.text[self.text_idx] in '_0123456789abcdefABCDEF': - self.text_idx += 1 - elif ch == 'B': # binary - self.text_idx += 1 - while self.text[self.text_idx] in '_01': - self.text_idx += 1 - elif ch >= '0' and ch <= 7: # octal (but allow decimal) - self.text_idx += 1 - while self.text[self.text_idx] in '_0123456789': - self.text_idx += 1 - else: - # either just 0 or 0.1 or 0UL, etc - pass - else: - # Regular int or float - while self.text[self.text_idx] in '_0123456789': - self.text_idx += 1 - - # Check if we stopped on a decimal point - if self.text[self.text_idx] == '.': - self.text_idx += 1 - token_type = 3 # float - if did_hex: - while self.text[self.text_idx] in '_0123456789abcdefABCDEF': - self.text_idx += 1 - else: - while self.text[self.text_idx] in '_0123456789': - self.text_idx += 1 - - # Check exponent - # Valid exponents per language (not that it matters): - # C/C++/D/Java: eEpP - # C#/Pawn: eE - if self.text[self.text_idx] in 'eEpP': - token_type = 3 # float - self.text_idx += 1 - if self.text[self.text_idx] in '+-': - self.text_idx += 1 - while self.text[self.text_idx] in '_0123456789': - self.text_idx += 1 - - # Check the suffixes - # Valid suffixes per language (not that it matters): - # Integer Float - # C/C++: uUlL lLfF - # C#: uUlL fFdDMm - # D: uUL ifFL - # Java: lL fFdD - # Pawn: (none) (none) - # - # Note that i, f, d, and m only appear in floats. - while 1: - if self.text[self.text_idx] in 'tTfFdDmM': - token_type = 3 # float - elif not self.text[self.text_idx] in 'lLuU': - break - self.text_idx += 1 - - self.tokens.append((self.text[start_idx : self.text_idx], token_type)) - return True - -text = """ -1.23+4-3*16%2 *sin(1.e-3 + .5p32) "hello" and "hello\\"there" -123 // some comment -a = b + c; -#define abc \\ - 5 -d = 5 /* hello */ + 3; -""" - -t = Tokenizer() -t.tokenize_text(text) -print(t.tokens) - diff --git a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/update_emscripten_bindings.py b/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/update_emscripten_bindings.py deleted file mode 100644 index 781311e2..00000000 --- a/debian/uncrustify-trinity/uncrustify-trinity-0.75.0/scripts/update_emscripten_bindings.py +++ /dev/null @@ -1,316 +0,0 @@ -#!/bin/python -from __future__ import print_function # python >= 2.6, chained 'with' >= 2.7 - -from os.path import dirname, abspath -from os import fdopen as os_fdopen, remove as os_remove, name as os_name -from shutil import copy2 -from subprocess import Popen, PIPE -from sys import exit as sys_exit, stderr -from tempfile import mkstemp -from contextlib import contextmanager -from threading import Timer -import re - - -ROOT_DIR = dirname(dirname(abspath(__file__))) - -# ============================================================================== - -FILE_BINDINGS = "%s/src/uncrustify_emscripten.cpp" % ROOT_DIR -FILE_TS = "%s/emscripten/libUncrustify.d.ts" % ROOT_DIR - -REGION_START = "region enum bindings" -REGION_END = "endregion enum bindings" - -''' Enums which values need to be updated in the binding code ''' -ENUMS_INFO = [ - { - 'name': 'option_type_e', - 'substitute_name': 'OptionType', - 'filepath': '%s/src/option.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': [], - 'suffix_chars': 0, - }, - { - 'name': 'iarf_e', - 'substitute_name': 'IARF', - 'filepath': '%s/src/option.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': ['NOT_DEFINED'], - 'suffix_chars': 0, - }, - { - 'name': 'line_end_e', - 'substitute_name': 'LineEnd', - 'filepath': '%s/src/option.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': [], - 'suffix_chars': 0, - }, - { - 'name': 'token_pos_e', - 'substitute_name': 'TokenPos', - 'filepath': '%s/src/option.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': [], - 'suffix_chars': 0, - }, - { - 'name': 'log_sev_t', - 'substitute_name': 'LogType', - 'filepath': '%s/src/log_levels.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': [], - 'suffix_chars': 1, - }, - { - 'name': 'E_Token', - 'substitute_name': 'TokenType', - 'filepath': '%s/src/token_enum.h' % ROOT_DIR, - 'extra_arg': [], - 'filter_values': ['CT_TOKEN_COUNT_'], - 'suffix_chars': 3, - }, - { - 'name': 'lang_flag_e', - 'substitute_name': 'Language', - 'filepath': '%s/src/uncrustify_types.h' % ROOT_DIR, - 'extra_arg': ["-extra-arg=-std=c++1z", "-extra-arg=-DEMSCRIPTEN"], - 'filter_values': [ - 'LANG_ALLC', - 'LANG_ALL', - 'FLAG_HDR', - 'FLAG_DIG', - 'FLAG_PP', - ], - 'suffix_chars': 5, - }, -] - -# ============================================================================== - -NULL_DEV = "/dev/null" if os_name != "nt" else "nul" - - -@contextmanager -def make_raw_temp_file(*args, **kwargs): - fd, tmp_file_name = mkstemp(*args, **kwargs) - try: - yield (fd, tmp_file_name) - finally: - os_remove(tmp_file_name) - - -@contextmanager -def open_fd(*args, **kwargs): - fp = os_fdopen(*args, **kwargs) - try: - yield fp - finally: - fp.close() - - -def term_proc(proc, timeout): - """ - helper function terminate a process if a timer times out - - :param proc: the process object that is going to be terminated - :param timeout: value that will be set to indicate termination - """ - timeout["value"] = True - proc.terminate() - - -def proc_output(args, timeout_sec=10): - """ - grabs output from called program - :param args: string array containing program name and program arguments - :param timeout_sec: max sec the program can run without being terminated - :return: utf8 decoded program output in a string - """ - proc = Popen(args, stdout=PIPE) - - timeout = {"value": False} - if timeout_sec is not None: - timeout = {"value": False} - timer = Timer(timeout_sec, term_proc, [proc, timeout]) - timer.start() - - output_b, error_txt_b = proc.communicate() - - if timeout_sec is not None: - timer.cancel() - - output = output_b.decode("UTF-8") - - if timeout["value"]: - print("proc timeout: %s" % ' '.join(args), file=stderr) - - return output if not timeout["value"] else None - - -def get_enum_lines(enum_info): - """ - extracts enum values from a file via clang-check - - :param enum_info: dict with: - 'name' (name of the enum), - 'filepath' (file containing the enum definition), - 'extra_arg' (extra arguments passed to clang-check) - :return: list containing enum values - """ - cut_len = len(enum_info['name']) - - proc_args = ["clang-check", enum_info['filepath'], "-ast-dump", - '-ast-dump-filter=%s' % enum_info['name']] - proc_args += enum_info['extra_arg'] - - output = proc_output(proc_args) - if output is None or len(output) == 0: - print("ScriptError: %s - empty clang-check return" % get_enum_lines.__name__, - file=stderr) - return () - - reg_obj = re.compile("EnumConstantDecl.+col:\d+ (referenced )?(\w+)") - - lines = [m.group(2) for l in output.splitlines() - for m in [re.search(reg_obj, l)] if m] - lines = [line for line in lines if line not in enum_info['filter_values']] - - if len(lines) == 0: - print("ScriptError: %s - no enum_info names found" % get_enum_lines.__name__, - file=stderr) - return () - return lines - - -def write_ts(opened_file_obj, enum_info): - """ - writes enum values in a specific typescript d.ts file format - - :param opened_file_obj: opened file file object (with write permissions) - :param enum_info: dict with: - 'name' (name of the enum), - 'substitute_name' (substitute name for the enum), - 'filepath' (file containing the enum definition), - 'extra_arg' (extra arguments passed to clang-check) - :return: False on failure else True - """ - lines = get_enum_lines(enum_info) - if len(lines) == 0: - return False - - opened_file_obj.write( - ' export interface %sValue extends EmscriptenEnumTypeObject {}\n' - ' export interface %s extends EmscriptenEnumType\n' - ' {\n' - % (enum_info['substitute_name'], enum_info['substitute_name']) - ) - for line in lines: - opened_file_obj.write( - ' %s : %sValue;\n' - % (line[enum_info['suffix_chars']:], enum_info['substitute_name']) - ) - opened_file_obj.write( - ' }\n\n' - ) - return True - - -def write_bindings(opened_file_obj, enum_info): - """ - writes enum values in a specific emscripten embind enum bindings format - - :param opened_file_obj: opened file file object (with write permissions) - :param enum_info: dict with: - 'name' (name of the enum), - 'filepath' (file containing the enum definition), - 'extra_arg' (extra arguments passed to clang-check) - :return: False on failure else True - """ - lines = get_enum_lines(enum_info) - if len(lines) == 0: - return False - - opened_file_obj.write( - ' enum_<%s>("%s")' % (enum_info['name'], enum_info['substitute_name']) - ) - for line in lines: - opened_file_obj.write( - '\n .value("%s", %s::%s)' - % (line[enum_info['suffix_chars']:], enum_info['name'], line) - ) - opened_file_obj.write( - ';\n\n' - ) - return True - - -def update_file(file_path, writer_func, enums_info): - """ - reads in a file and replaces old enum value in a region, which is defined by - region start and end string, with updated ones - - :param file_path: file in which the replacement will be made - :param writer_func: name of the function that will be called to write new - content - :param enums_info:list of dicts each containing: - 'name' (name of the enum), - 'substitute_name' (substitute name for the enum), - 'filepath' (file containing the enum definition), - 'extra_arg' (extra arguments passed to clang-check) - :return: False on failure else True - """ - in_target_region = False - - reg_obj_start = re.compile(".*%s$" % REGION_START) - reg_obj_end = re.compile(".*%s$" % REGION_END) - reg_obj = reg_obj_start - - with make_raw_temp_file(suffix='.unc') as (fd, tmp_file_path): - with open(file_path, 'r') as fr, open_fd(fd, 'w') as fw: - for line in fr: - match = None if reg_obj is None else re.search(reg_obj, line) - - if match is None and not in_target_region: - fw.write(line) # write out of region code - - elif match is not None and not in_target_region: - fw.write(line) # hit the start region - - in_target_region = True - reg_obj = reg_obj_end - - for enum in enums_info: - succes_flag = writer_func(fw, enum) - if not succes_flag: # abort, keep input file clean - return False - - elif match is None and in_target_region: - pass # ignore old binding code - - elif match and in_target_region: # hit the endregion - fw.write(line) - - in_target_region = False - reg_obj = None - - copy2(tmp_file_path, file_path) # overwrite input file - return True - - -def main(): - flag = update_file(FILE_BINDINGS, write_bindings, ENUMS_INFO) - if not flag: - return 1 - - flag = update_file(FILE_TS, write_ts, ENUMS_INFO) - if not flag: - return 1 - - return 0 - - -if __name__ == "__main__": - sys_exit(main()) |