[sgen] Fix logging of major heap size with concurrent sweep
[mono.git] / mcs / mcs / Makefile
1 # To produce a debugging parser, use the version that says "-cvt"
2 JAY_FLAGS=-c
3 # JAY_FLAGS=-cvt
4
5 thisdir := mcs
6 SUBDIRS := 
7 include ../build/rules.make
8
9 EXTRA_DISTFILES = \
10         mcs.csproj              \
11         mcs.sln         \
12         cs-parser.jay           \
13         mcs.exe.sources
14
15 LIB_REFS = System System.Core System.Xml
16
17 ifeq (basic, $(PROFILE))
18 PROGRAM = basic.exe
19 sourcefile = mcs.exe.sources
20 else
21 PROGRAM_USE_INTERMEDIATE_FILE = true
22 PROGRAM = mcs.exe
23 the_libdir = $(topdir)/class/lib/build/
24 LOCAL_MCS_FLAGS += -lib:$(topdir)/class/lib/build -debug
25 endif
26
27 LOCAL_MCS_FLAGS += -d:STATIC,NO_SYMBOL_WRITER,NO_AUTHENTICODE -r:System.Core.dll -r:System.Xml.dll
28
29 ifndef NO_THREAD_ABORT
30 REFERENCE_SOURCES_FLAGS += -d:MONO_FEATURE_THREAD_ABORT
31 endif
32
33 ifndef NO_PROCESS_START
34 REFERENCE_SOURCES_FLAGS += -d:MONO_FEATURE_PROCESS_START
35 endif
36
37 LOCAL_MCS_FLAGS += $(REFERENCE_SOURCES_FLAGS)
38
39 PROGRAM_INSTALL_DIR = $(mono_libdir)/mono/4.5
40
41 PROGRAM_COMPILE = $(BOOT_COMPILE)
42
43 BUILT_SOURCES = cs-parser.cs
44
45 CLEAN_FILES += y.output
46
47 %-parser.cs: %-parser.jay $(topdir)/jay/skeleton.cs
48         $(topdir)/jay/jay $(JAY_FLAGS) < $(topdir)/jay/skeleton.cs $< > jay-tmp.out && mv jay-tmp.out $@
49
50 KEEP_OUTPUT_FILE_COPY = yes
51
52 include ../build/executable.make
53
54 #
55 # Below this line we have local targets used for testing and development
56 #
57
58 # Testing targets
59
60 TIME = time
61
62 # This used to be called test, but that conflicts with the global
63 # recursive target.
64
65 btest: mcs2.exe mcs3.exe
66         ls -l mcs2.exe mcs3.exe
67
68 mcs2.exe: $(PROGRAM)
69         $(TIME) $(RUNTIME) $(RUNTIME_FLAGS) $(PROGRAM) $(USE_MCS_FLAGS) -target:exe -out:$@ $(BUILT_SOURCES) @$(response)
70
71 mcs3.exe: mcs2.exe
72         $(TIME) $(RUNTIME) $(RUNTIME_FLAGS) ./mcs2.exe $(USE_MCS_FLAGS) -target:exe -out:$@ $(BUILT_SOURCES) @$(response)
73
74 wc:
75         wc -l $(BUILT_SOURCES) `cat $(sourcefile)`
76
77 # we need this because bash tries to use its own crappy timer
78 FRIENDLY_TIME = $(shell which time) -f'%U seconds'
79
80 do-time : $(PROGRAM)
81         @ echo -n "Run 1:   "
82         @ rm -f mcs2.exe
83         @ $(MAKE) TIME="$(FRIENDLY_TIME)" mcs2.exe > /dev/null || (echo FAILED; exit 1)
84         @ echo -n "Run 2:   "
85         @ rm -f mcs3.exe
86         @ $(MAKE) TIME="$(FRIENDLY_TIME)" mcs3.exe > /dev/null || (echo FAILED; exit 1)
87         @ $(MAKE) do-corlib
88
89 do-corlib:
90         @ echo -n "corlib:  "
91         @ rm -f ../class/lib/mscorlib.dll
92         @ cd ../class/corlib ; $(MAKE) BOOTSTRAP_MCS='$(FRIENDLY_TIME) mono $$(topdir)/class/lib/$(PROFILE)/mcs.exe' > /dev/null || (echo FAILED; exit 1)
93
94 PROFILER=default
95
96 do-gettext:
97         xgettext --keyword='Report.Error:3' --keyword='Report.Error:2' --keyword='Report.Warning:3' --keyword='Report.Warning:2' -o mcs.po --language='C#' `cat gmcs.exe.sources | grep -v /`
98
99 profile : $(PROGRAM)
100         $(RUNTIME) $(RUNTIME_FLAGS) --profile=$(PROFILER) $(PROGRAM) $(USE_MCS_FLAGS) -target:exe -out:mcs2.exe $(BUILT_SOURCES) @$(response)
101
102 debug-parser:
103         rm cs-parser.cs
104         $(MAKE) JAY_FLAGS=-cvt
105
106 #
107 # quick hack target, to quickly develop the gmcs compiler
108 # Update manually.
109
110 q: cs-parser.cs qh
111         echo 'System.Console.WriteLine ("Hello");' | mono csharp.exe
112         echo -e 'using System;\nConsole.WriteLine ("hello");' | mono csharp.exe
113         echo -e '"foo" == "bar";' | mono csharp.exe
114         echo -e 'var a = 1;\na + 2;' | mono csharp.exe
115         echo -e 'int j;\nj = 1;' | mono csharp.exe
116         echo -e 'var a = new int[]{1,2,3};\nfrom x in a select x;' | mono csharp.exe
117         echo -e 'var a = from f in System.IO.Directory.GetFiles ("/tmp") where f == "passwd" select f;' | mono csharp.exe
118
119