File: abicheck.sh

package info (click to toggle)
wxpython4.0 4.2.3%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 221,752 kB
  • sloc: cpp: 962,555; python: 230,573; ansic: 170,731; makefile: 51,756; sh: 9,342; perl: 1,564; javascript: 584; php: 326; xml: 200
file content (84 lines) | stat: -rwxr-xr-x 2,855 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#!/bin/bash

# Script originally based on GTK+'s own abicheck.sh; it should be run anytime
# there is a change in the stable branch of wxWidgets which could lead to an
# ABI breakage and thus result in a binary-incompatible change (see tech docs).
#


expected_abi_file="expected_abi"
actual_abi_file="actual_abi"

if [[ "$(uname)" == "Darwin" ]]; then
   file_mask=*.dylib
   nm_options="-g -U"
else
   file_mask=*.so
   nm_options="-D -g --defined-only"
fi

if [[ "$1" == "--generate" ]]; then

    # IMPORTANT: we need a shared build of wxWidgets to proceed
    if [[ $(echo $file_mask) == "$file_mask" ]]; then
        echo "No shared objects ($file_mask) were found... aborting"
        exit 1
    fi

    # generated the "expected ABI" for later comparison
    rm -f $expected_abi_file
    for library in $file_mask; do
        # NOTE: don't use -C option as otherwise cut won't work correctly
        nm $nm_options $library | cut -d ' ' -f 2,3 | sort >>$expected_abi_file
    done

    echo "Expected wxWidgets ABI generated in \"$expected_abi_file\"..."

elif [[ -z "$1" ]]; then

    if [[ ! -f "$expected_abi_file" ]]; then
        echo "The file containing the expected wxWidgets ABI '$expected_abi_file' does not exist!"
        echo "Please generate it first using the '--generate' option"
        exit 1
    fi

    echo "Comparing actual ABI with the expected ABI (loading it from \"$expected_abi_file\")..."

    # IMPORTANT: we need a shared build of wxWidgets to do the check
    if [[ $(echo $file_mask) == "*$file_mask" ]]; then
        echo "No shared objects ($file_mask) were found... aborting"
        exit 1
    fi

    rm -f $actual_abi_file
    for library in $file_mask; do
        # NOTE: don't use -C option as otherwise cut won't work correctly
        nm $nm_options $library | cut -d ' ' -f 2,3 | sort >>$actual_abi_file
    done

    result=`diff -u $expected_abi_file $actual_abi_file`

    if [[ -z "$result" ]]; then
        echo "No binary (in)compatible changes were found."
    else
        echo "========================================================="
        echo "WARNING: Possible binary-incompatible changes were found:"
        echo "========================================================="
        echo
        echo "$result"

        # this doesn't necessarly indicate that binary compatibility was surely
        # broken; e.g. adding non-virtual methods will generate a new line in the
        # $actual_abi_file but that's a compatible change.
    fi

else

    echo "Usage: $0 [--generate]"
    echo "When running without options, compares the wxWidgets ABI saved in '$expected_abi_file'"
    echo "with the current ABI of the .so files of the working directory."
    echo "When --generate is given, saves in '$expected_abi_file' the ABI of the .so files"
    echo "(for later comparisons)."

fi