Merge pull request #3289 from BrzVlad/fix-critical-finalizer
[mono.git] / mcs / tools / mono-symbolicate / Makefile
1 thisdir = tools/mono-symbolicate
2 SUBDIRS =
3 include ../../build/rules.make
4
5 PROGRAM = mono-symbolicate.exe
6
7 LOCAL_MCS_FLAGS = \
8         /D:NO_AUTHENTICODE
9
10 LIB_REFS = Mono.Cecil Mono.Cecil.Mdb System.Xml System.Core System
11
12 include ../../build/executable.make
13
14 LIB_PATH = $(topdir)/class/lib/$(PROFILE)
15
16 MONO = MONO_PATH="$(LIB_PATH)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" $(RUNTIME) -O=-inline
17
18 MSYM_DIR = $(OUT_DIR)/msymdir
19 TEST_CS = Test/StackTraceDumper.cs
20 TEST_EXE = $(OUT_DIR)/StackTraceDumper.exe
21 STACKTRACE_FILE = $(OUT_DIR)/stacktrace.out
22 SYMBOLICATE_RAW_FILE = $(OUT_DIR)/symbolicate_raw.out
23 SYMBOLICATE_RESULT_FILE = $(OUT_DIR)/symbolicate.result
24 SYMBOLICATE_EXPECTED_FILE = Test/symbolicate.expected
25
26 CHECK_DIFF = @\
27         $(MONO) $(TEST_EXE) > $(STACKTRACE_FILE); \
28         $(MONO) $(LIB_PATH)/$(PROGRAM) $(MSYM_DIR) $(STACKTRACE_FILE) > $(SYMBOLICATE_RAW_FILE); \
29         sed "s/) .* in .*\/mcs\//) in mcs\//" $(SYMBOLICATE_RAW_FILE) | sed '/\[MVID\]/d' | sed '/\[AOTID\]/d' > $(SYMBOLICATE_RESULT_FILE); \
30         DIFF=$$(diff $(SYMBOLICATE_RESULT_FILE) $(SYMBOLICATE_EXPECTED_FILE)); \
31         if [ ! -z "$$DIFF" ]; then \
32                 echo "Symbolicate tests failed."; \
33                 echo "If $(SYMBOLICATE_RESULT_FILE) is correct copy it to $(SYMBOLICATE_EXPECTED_FILE)."; \
34                 echo "Otherwise runtime sequence points need to be fixed."; \
35                 echo "$$DIFF"; \
36                 exit 1; \
37         fi
38
39 PREPARE_OUTDIR = @\
40         rm -rf $(OUT_DIR); \
41         mkdir -p $(OUT_DIR); \
42         mkdir -p $(MSYM_DIR);
43
44 COMPILE = \
45         $(CSCOMPILE) $(TEST_CS) -out:$(TEST_EXE); \
46         $(MONO) $(LIB_PATH)/$(PROGRAM) store-symbols $(MSYM_DIR) $(OUT_DIR); \
47         $(MONO) $(LIB_PATH)/$(PROGRAM) store-symbols $(MSYM_DIR) $(LIB_PATH);
48
49 check: test-local
50
51 AOT_SUPPORTED = $(shell $(MONO) --aot 2>&1 | grep -q "AOT compilation is not supported" && echo 0 || echo 1)
52
53 test-local: test-without-aot test-with-aot test-with-aot-msym
54
55 test-without-aot: OUT_DIR = Test/without_aot
56 test-without-aot: all
57         @echo "Checking $(TEST_EXE) without AOT in $(OUT_DIR)"
58         $(PREPARE_OUTDIR)
59         $(COMPILE)
60         $(CHECK_DIFF)
61
62 test-with-aot: OUT_DIR = Test/with_aot
63 test-with-aot: all
64 ifeq ($(AOT_SUPPORTED), 1)
65         @echo "Checking $(TEST_EXE) with AOT in $(OUT_DIR)"
66         $(PREPARE_OUTDIR)
67         $(COMPILE)
68         @$(MONO) --aot $(TEST_EXE) > /dev/null
69         $(CHECK_DIFF)
70 endif
71
72 test-with-aot-msym: OUT_DIR = Test/with_aot_msym
73 test-with-aot-msym: all
74 ifeq ($(AOT_SUPPORTED), 1)
75         @echo "Checking $(TEST_EXE) with AOT (using .msym) in $(OUT_DIR)"
76         $(PREPARE_OUTDIR)
77         $(COMPILE)
78         @$(MONO) --aot=msym-dir=$(MSYM_DIR) $(TEST_EXE) > /dev/null
79         $(CHECK_DIFF)
80 endif