Mxx_ru 1.3.0 → 1.3.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. data/COPYING +26 -26
  2. data/NEWS +107 -107
  3. data/README +21 -21
  4. data/Rakefile +56 -59
  5. data/examples/exe_and_lib/prj.rb +11 -11
  6. data/examples/exe_and_lib/say.rb +7 -7
  7. data/examples/exe_dll_lib/inout.rb +18 -18
  8. data/examples/exe_dll_lib/prj.rb +11 -11
  9. data/examples/exe_dll_lib/say.rb +9 -9
  10. data/examples/exe_dll_lib_2/build.rb +10 -10
  11. data/examples/exe_dll_lib_2/inout/prj.rb +16 -16
  12. data/examples/exe_dll_lib_2/main/prj.rb +9 -9
  13. data/examples/exe_dll_lib_2/say/prj.rb +8 -8
  14. data/examples/simple_exe/prj.rb +7 -7
  15. data/lib/mxx_ru/abstract_target.rb +335 -335
  16. data/lib/mxx_ru/binary_library.rb +106 -106
  17. data/lib/mxx_ru/binary_target.rb +173 -173
  18. data/lib/mxx_ru/binary_unittest.rb +143 -143
  19. data/lib/mxx_ru/compat.rb +33 -33
  20. data/lib/mxx_ru/cpp.rb +38 -38
  21. data/lib/mxx_ru/cpp/analyzer.rb +237 -237
  22. data/lib/mxx_ru/cpp/composite.rb +118 -118
  23. data/lib/mxx_ru/cpp/detect_toolset.rb +122 -122
  24. data/lib/mxx_ru/cpp/mode.rb +90 -90
  25. data/lib/mxx_ru/cpp/obj_placement.rb +330 -330
  26. data/lib/mxx_ru/cpp/obj_placements/custom_subdir.rb +155 -155
  27. data/lib/mxx_ru/cpp/qt.rb +366 -366
  28. data/lib/mxx_ru/cpp/rucodegen.rb +157 -157
  29. data/lib/mxx_ru/cpp/source_file.rb +79 -79
  30. data/lib/mxx_ru/cpp/target.rb +1523 -1523
  31. data/lib/mxx_ru/cpp/toolset.rb +1087 -1087
  32. data/lib/mxx_ru/cpp/toolsets/bcc_win32_5.rb +53 -53
  33. data/lib/mxx_ru/cpp/toolsets/bcc_win32_family.rb +460 -460
  34. data/lib/mxx_ru/cpp/toolsets/c89_etk_nsk.rb +59 -59
  35. data/lib/mxx_ru/cpp/toolsets/c89_nsk.rb +59 -59
  36. data/lib/mxx_ru/cpp/toolsets/c89_nsk_family.rb +277 -277
  37. data/lib/mxx_ru/cpp/toolsets/gcc_cygwin.rb +58 -58
  38. data/lib/mxx_ru/cpp/toolsets/gcc_family.rb +420 -424
  39. data/lib/mxx_ru/cpp/toolsets/gcc_linux.rb +64 -64
  40. data/lib/mxx_ru/cpp/toolsets/gcc_mingw.rb +150 -150
  41. data/lib/mxx_ru/cpp/toolsets/gcc_sparc_solaris.rb +91 -91
  42. data/lib/mxx_ru/cpp/toolsets/gcc_unix_family.rb +103 -84
  43. data/lib/mxx_ru/cpp/toolsets/vc7.rb +62 -62
  44. data/lib/mxx_ru/cpp/toolsets/vc8.rb +455 -455
  45. data/lib/mxx_ru/cpp/toolsets/vc_family.rb +448 -448
  46. data/lib/mxx_ru/ex.rb +165 -165
  47. data/lib/mxx_ru/makestyle_generator.rb +146 -146
  48. data/lib/mxx_ru/textfile_unittest.rb +303 -303
  49. data/lib/mxx_ru/util.rb +340 -340
  50. data/tests/c/pcre/chartables.c +183 -183
  51. data/tests/c/pcre/config.h +99 -99
  52. data/tests/c/pcre/dftables.c +167 -167
  53. data/tests/c/pcre/get.c +349 -349
  54. data/tests/c/pcre/internal.h +677 -677
  55. data/tests/c/pcre/maketables.c +140 -140
  56. data/tests/c/pcre/pcre.c +8304 -8304
  57. data/tests/c/pcre/pcre.h +193 -193
  58. data/tests/c/pcre/pcre.rb +14 -14
  59. data/tests/c/pcre/pcredemo.c +316 -316
  60. data/tests/c/pcre/pcregrep.c +642 -642
  61. data/tests/c/pcre/pcreposix.c +305 -305
  62. data/tests/c/pcre/pcreposix.h +88 -88
  63. data/tests/c/pcre/pcretest.c +1483 -1483
  64. data/tests/c/pcre/perltest +211 -211
  65. data/tests/c/pcre/printint.c +360 -360
  66. data/tests/c/pcre/study.c +472 -472
  67. data/tests/cpp/cpp_sources_glob/build.rb +7 -7
  68. data/tests/cpp/cpp_sources_glob/some/module/prj.rb +10 -10
  69. data/tests/cpp/cpp_sources_glob/tc_cpp_sources_glob.rb +18 -18
  70. data/tests/cpp/mswin_res_dll/build.rb +14 -14
  71. data/tests/cpp/mswin_res_dll/dll.cpp +17 -17
  72. data/tests/cpp/mswin_res_dll/dll.rb +29 -29
  73. data/tests/cpp/mswin_res_dll/dll.rc +48 -48
  74. data/tests/cpp/mswin_res_dll/h/dll.hpp +8 -8
  75. data/tests/cpp/mswin_res_dll/h/res.h +3 -3
  76. data/tests/cpp/mswin_res_dll/main.cpp +13 -13
  77. data/tests/cpp/mswin_res_dll/main.rb +19 -19
  78. data/tests/cpp/mswin_res_dll/tc_mswin_res_dll.rb +18 -18
  79. data/tests/cpp/mswin_res_exe/build.rb +23 -23
  80. data/tests/cpp/mswin_res_exe/h/res.h +3 -3
  81. data/tests/cpp/mswin_res_exe/main.cpp +17 -17
  82. data/tests/cpp/mswin_res_exe/main.rc +48 -48
  83. data/tests/cpp/mswin_res_exe/tc_mswin_res_exe.rb +18 -18
  84. data/tests/cpp/rucodegen.embedded/host_config.cpp +32 -32
  85. data/tests/cpp/rucodegen.embedded/impl/conn_params.cpp +7 -7
  86. data/tests/cpp/rucodegen.embedded/impl/conn_params.rb +14 -14
  87. data/tests/cpp/rucodegen.embedded/impl/h/conn_params.hpp +10 -10
  88. data/tests/cpp/rucodegen.embedded/prj.rb +16 -16
  89. data/tests/cpp/rucodegen.embedded/tc_rucodegen.rb +18 -18
  90. data/tests/cpp/rucodegen/host_config.cpp +20 -20
  91. data/tests/cpp/rucodegen/host_config.rb +14 -14
  92. data/tests/cpp/rucodegen/impl/conn_params.cpp +7 -7
  93. data/tests/cpp/rucodegen/impl/conn_params.rb +14 -14
  94. data/tests/cpp/rucodegen/impl/h/conn_params.hpp +10 -10
  95. data/tests/cpp/rucodegen/prj.rb +16 -16
  96. data/tests/cpp/rucodegen/tc_rucodegen.rb +18 -18
  97. data/tests/cpp/textfile_unittest/build.rb +8 -8
  98. data/tests/cpp/textfile_unittest/etalons/out_1.txt +1 -1
  99. data/tests/cpp/textfile_unittest/etalons/out_128.txt +128 -128
  100. data/tests/cpp/textfile_unittest/main.cpp +89 -89
  101. data/tests/cpp/textfile_unittest/prj.rb +8 -8
  102. data/tests/cpp/textfile_unittest/prj.ut.rb +18 -18
  103. data/tests/cpp/textfile_unittest/tc_textfile_unittest.rb +18 -18
  104. data/tests/cpp/toolset_name.rb +6 -6
  105. data/tests/cpp/vc_cleanup/prj_dll_no_implib.rb +10 -10
  106. data/tests/cpp/vc_cleanup/prj_dll_no_implib_simple_target_root.rb +11 -11
  107. data/tests/cpp/vc_cleanup/prj_dll_with_implib.rb +11 -11
  108. data/tests/cpp/vc_cleanup/prj_dll_with_implib_simple_target_root.rb +14 -14
  109. data/tests/cpp/vc_cleanup/prj_exe_no_implib.rb +10 -10
  110. data/tests/cpp/vc_cleanup/prj_exe_no_implib_simple_target_root.rb +11 -11
  111. data/tests/cpp/vc_cleanup/prj_lib.rb +10 -10
  112. data/tests/cpp/vc_cleanup/prj_lib_with_simple_target_root.rb +11 -11
  113. data/tests/cpp/vc_cleanup/tc_vc_cleanup.rb +23 -23
  114. data/tests/mxx_ru/binary_library/tc_binary_library.rb +57 -57
  115. data/tests/mxx_ru/binary_library/tc_binary_target_lib_methods.rb +114 -114
  116. data/tests/mxx_ru/change_default_value/ignoring_by_build_root/build.rb +8 -8
  117. data/tests/mxx_ru/change_default_value/ignoring_by_build_root/child_1.rb +5 -5
  118. data/tests/mxx_ru/change_default_value/ignoring_by_child_1/build.rb +7 -7
  119. data/tests/mxx_ru/change_default_value/ignoring_by_child_1/child_1.rb +5 -5
  120. data/tests/mxx_ru/change_default_value/ignoring_by_child_1/child_2.rb +5 -5
  121. data/tests/mxx_ru/change_default_value/ok/build.rb +8 -8
  122. data/tests/mxx_ru/change_default_value/ok/child_1.rb +8 -8
  123. data/tests/mxx_ru/lib_path/build.rb +8 -8
  124. data/tests/mxx_ru/lib_path/bye.rb +8 -8
  125. data/tests/mxx_ru/lib_path/hi.rb +8 -8
  126. data/tests/mxx_ru/lib_path/main.rb +12 -12
  127. data/tests/mxx_ru/lib_path/tc_lib_path.rb +18 -18
  128. data/tests/mxx_ru/obj_placements/tc_custom_subdir.rb +58 -58
  129. data/tests/mxx_ru/opt_lib_ext/build.rb +7 -7
  130. data/tests/mxx_ru/opt_lib_ext/hi.rb +7 -7
  131. data/tests/mxx_ru/opt_lib_ext/tc_opt_lib_ext.rb +18 -18
  132. data/tests/mxx_ru/opt_lib_ext/test-no-ext.rb +9 -9
  133. data/tests/mxx_ru/opt_lib_ext/test-with-ext.rb +13 -13
  134. data/tests/mxx_ru/plural_form_methods/tc.rb +72 -72
  135. data/tests/mxx_ru/qt_gen/tc_uic_result_subdir.rb +76 -76
  136. data/tests/mxx_ru/target_ext/prj_dll.rb +8 -8
  137. data/tests/mxx_ru/target_ext/prj_exe.rb +8 -8
  138. data/tests/mxx_ru/target_ext/prj_lib.rb +8 -8
  139. data/tests/mxx_ru/target_ext/tc_target_ext.rb +24 -24
  140. data/tests/mxx_ru/tc_makestyle_generator.rb +117 -117
  141. data/tests/mxx_ru/vc8/tc_actual_manifest.rb +230 -230
  142. data/tests/mxx_ru/vc8/tc_append_mt_commands.rb +104 -104
  143. data/tests/mxx_ru/vc8/tc_default_manifest.rb +17 -17
  144. data/tests/mxx_ru/vc8/tc_define_manifest.rb +173 -173
  145. data/tests/mxx_ru/vc8/tc_drop_default_manifest.rb +16 -16
  146. data/tests/mxx_ru/vc8/tc_invalid_params.rb +81 -81
  147. data/tests/mxx_ru/vc8/ts_vc8.rb +10 -10
  148. data/tests/qt/aclock/aclock.cpp +148 -148
  149. data/tests/qt/aclock/aclock.h +45 -45
  150. data/tests/qt/aclock/main.cpp +28 -28
  151. data/tests/qt/aclock/prj.rb +21 -21
  152. data/tests/qt/iconview/main.cpp +76 -76
  153. data/tests/qt/iconview/prj.rb +21 -21
  154. data/tests/qt/toplevel/main.cpp +9 -9
  155. data/tests/qt/toplevel/options.ui +587 -587
  156. data/tests/qt/toplevel/prj.rb +22 -22
  157. data/tests/test_with_compilation.rb +110 -110
  158. data/tests/unix/lib_linking_mode/a_shared.rb +7 -7
  159. data/tests/unix/lib_linking_mode/a_static.rb +7 -7
  160. data/tests/unix/lib_linking_mode/etalon/shared.txt +2 -2
  161. data/tests/unix/lib_linking_mode/etalon/static.txt +2 -2
  162. data/tests/unix/lib_linking_mode/main_conflict.rb +12 -12
  163. data/tests/unix/lib_linking_mode/main_conflict_2.rb +11 -11
  164. data/tests/unix/lib_linking_mode/main_shared.rb +9 -9
  165. data/tests/unix/lib_linking_mode/main_shared.ut.rb +11 -11
  166. data/tests/unix/lib_linking_mode/main_shared_2.rb +10 -10
  167. data/tests/unix/lib_linking_mode/main_shared_2.ut.rb +11 -11
  168. data/tests/unix/lib_linking_mode/main_static.rb +9 -9
  169. data/tests/unix/lib_linking_mode/main_static.ut.rb +11 -11
  170. data/tests/unix/lib_linking_mode/main_static_2.rb +10 -10
  171. data/tests/unix/lib_linking_mode/main_static_2.ut.rb +11 -11
  172. data/tests/unix/lib_linking_mode/tc_conflicted_build.rb +18 -18
  173. data/tests/unix/lib_linking_mode/tc_normal_build.rb +18 -18
  174. data/tests/unix/lib_order/a.cpp +4 -0
  175. data/tests/unix/lib_order/a.hpp +1 -0
  176. data/tests/unix/lib_order/a.rb +8 -0
  177. data/tests/unix/lib_order/b.cpp +10 -0
  178. data/tests/unix/lib_order/b.hpp +1 -0
  179. data/tests/unix/lib_order/b.rb +8 -0
  180. data/tests/unix/lib_order/build.rb +9 -0
  181. data/tests/unix/lib_order/c.cpp +12 -0
  182. data/tests/unix/lib_order/c.hpp +2 -0
  183. data/tests/unix/lib_order/c.rb +8 -0
  184. data/tests/unix/lib_order/d.cpp +7 -0
  185. data/tests/unix/lib_order/d.hpp +1 -0
  186. data/tests/unix/lib_order/d.rb +8 -0
  187. data/tests/unix/lib_order/main.cpp +7 -0
  188. data/tests/unix/lib_order/main.rb +14 -0
  189. data/tests/unix/lib_order/tc_normal_build.rb +16 -0
  190. metadata +342 -319
data/lib/mxx_ru/ex.rb CHANGED
@@ -1,165 +1,165 @@
1
- #--
2
- # Copyright (c) 1996-2004, Yauheni Akhotnikau
3
- # Copyright (c) 2004-2006, JSC Intervale
4
- # Copyright (c) 2006, The Mxx_ru Project
5
- # All rights reserved.
6
- #
7
- # Redistribution and use in source and binary forms, with or without modification,
8
- # are permitted provided that the following conditions are met:
9
- #
10
- # 1. Redistributions of source code must retain the above copyright notice,
11
- # this list of conditions and the following disclaimer.
12
- # 2. Redistributions in binary form must reproduce the above copyright notice,
13
- # this list of conditions and the following disclaimer in the documentation
14
- # and/or other materials provided with the distribution.
15
- # 3. The name of the author may not be used to endorse or promote products derived
16
- # from this software without specific prior written permission.
17
- #
18
- # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
19
- # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
20
- # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
21
- # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
- # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23
- # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
- # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25
- # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26
- # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
- #++
28
-
29
- module MxxRu
30
-
31
- # Base class for all exceptions.
32
- class Ex < Exception
33
- end
34
-
35
- # Exception, thrown on execution of 'pure abstract method'.
36
- class AbstractMethodEx < Ex
37
- def initialize( method_name )
38
- super( "Pure virtual method call: " + method_name )
39
- end
40
- end
41
-
42
- # For compatibility with previous versions.
43
- Abstract_method_ex = AbstractMethodEx
44
-
45
- # Exception, thrown if returned object type is not expected.
46
- class InvalidCastEx < Ex
47
- def initialize( msg )
48
- super( msg )
49
- end
50
- end
51
-
52
- # For compatibility with previous versions.
53
- Invalid_cast_ex = InvalidCastEx
54
-
55
- # Exception, thrown if build commands fail.
56
- class BuildEx < Ex
57
- def initialize( cmd_line, desc )
58
- super( "Build error: '#{cmd_line}' returns '#{desc}'" )
59
- end
60
- end
61
-
62
- # For compatibility with previous versions.
63
- Build_ex = BuildEx
64
-
65
- # Exception, thrown if unknown target type is detected.
66
- class UnsupportedTargetTypeEx < Ex
67
- def initialize( target_class, target_type )
68
- super( "Unsupported target type '#{target_type}'" +
69
- " in '#{target_class}'" )
70
- end
71
- end
72
-
73
- # For compatibility with previous versions.
74
- Unsupported_target_type_ex = UnsupportedTargetTypeEx
75
-
76
- # Exception, thrown if no target object is found for given alias.
77
- class TargetUnknownEx < Ex
78
- def initialize( target_name )
79
- super( "Target unknown for: " + target_name )
80
- end
81
- end
82
-
83
- # For compatibility with previous versions.
84
- Target_unknown_ex = TargetUnknownEx
85
-
86
- # Exception, thrown if value conflict for global options such as
87
- # runtime_mode, rtl_mode, etc is detected
88
- class GlobalOptionConflictEx < Ex
89
- # [_a_name_] Option name.
90
- # [_a_current_] Current option value.
91
- # [_a_current_owner_] Who was set current value.
92
- # [_a_new_] New option value.
93
- # [_a_new_owner_] Who tries to set current value.
94
- def initialize(
95
- a_name,
96
- a_current,
97
- a_current_owner,
98
- a_new,
99
- a_new_owner )
100
-
101
- super( "Global option '#{a_name}' conflict detected! " +
102
- "Current value '#{a_current}' set by '#{a_current_owner}'. " +
103
- "New value '#{a_new}' required by '#{a_new_owner}'" )
104
- end
105
- end
106
-
107
- # For compatibility with previous versions.
108
- Global_option_conflict_ex = GlobalOptionConflictEx
109
-
110
- # Exception, thrown if anyone tries to set invalid value to global options
111
- # such as runtime_mode, rtl_mode, etc.
112
- class GlobalOptionDisallowedValueEx < Ex
113
- # [_a_name_] Option name.
114
- # [_a_available_values_] Available values list. Should be Array of String.
115
- # [_a_new_] New option value.
116
- # [_a_new_owner_] Who tries to set new value.
117
- def initialize(
118
- a_name,
119
- a_available_values,
120
- a_new,
121
- a_new_owner )
122
-
123
- super( "Value '#{new}' required by '#{a_new_owner}' " +
124
- "disallowed for global option '#{a_name}'! " +
125
- "Allowed values are: #{a_available_values.join(' ')}" )
126
- end
127
- end
128
-
129
- # For compatibility with previous versions.
130
- Global_option_disallowed_value_ex = GlobalOptionDisallowedValueEx
131
-
132
- # Exception, thrown if some mode is not supported by the toolset.
133
- class UnsupportedModeEx < Ex
134
- def initialize( msg )
135
- super( msg )
136
- end
137
- end
138
-
139
- # For compatibility with previous versions.
140
- Unsupported_mode_ex = UnsupportedModeEx
141
-
142
- # Exception, thrown if some dependency file is missing.
143
- class MissingDependFileEx < Ex
144
- def initialize( missing_file, depend_for )
145
- super( "File '#{missing_file}' required by '#{depend_for}' " +
146
- "missing" )
147
- end
148
- end
149
-
150
- # For compatibility with previous versions.
151
- Missing_depend_file_ex = MissingDependFileEx
152
-
153
- # Exception, thrown if some value is invalid in current context.
154
- class InvalidValueEx < Ex
155
- def initialize( msg )
156
- super( msg )
157
- end
158
- end
159
-
160
- # For compatibility with previous versions.
161
- Invalid_value_ex = InvalidValueEx
162
-
163
- end
164
-
165
- load File.dirname( __FILE__ ) + '/compat.rb'
1
+ #--
2
+ # Copyright (c) 1996-2004, Yauheni Akhotnikau
3
+ # Copyright (c) 2004-2006, JSC Intervale
4
+ # Copyright (c) 2006, The Mxx_ru Project
5
+ # All rights reserved.
6
+ #
7
+ # Redistribution and use in source and binary forms, with or without modification,
8
+ # are permitted provided that the following conditions are met:
9
+ #
10
+ # 1. Redistributions of source code must retain the above copyright notice,
11
+ # this list of conditions and the following disclaimer.
12
+ # 2. Redistributions in binary form must reproduce the above copyright notice,
13
+ # this list of conditions and the following disclaimer in the documentation
14
+ # and/or other materials provided with the distribution.
15
+ # 3. The name of the author may not be used to endorse or promote products derived
16
+ # from this software without specific prior written permission.
17
+ #
18
+ # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
19
+ # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
20
+ # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
21
+ # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
+ # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23
+ # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
+ # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25
+ # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26
+ # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+ #++
28
+
29
+ module MxxRu
30
+
31
+ # Base class for all exceptions.
32
+ class Ex < Exception
33
+ end
34
+
35
+ # Exception, thrown on execution of 'pure abstract method'.
36
+ class AbstractMethodEx < Ex
37
+ def initialize( method_name )
38
+ super( "Pure virtual method call: " + method_name )
39
+ end
40
+ end
41
+
42
+ # For compatibility with previous versions.
43
+ Abstract_method_ex = AbstractMethodEx
44
+
45
+ # Exception, thrown if returned object type is not expected.
46
+ class InvalidCastEx < Ex
47
+ def initialize( msg )
48
+ super( msg )
49
+ end
50
+ end
51
+
52
+ # For compatibility with previous versions.
53
+ Invalid_cast_ex = InvalidCastEx
54
+
55
+ # Exception, thrown if build commands fail.
56
+ class BuildEx < Ex
57
+ def initialize( cmd_line, desc )
58
+ super( "Build error: '#{cmd_line}' returns '#{desc}'" )
59
+ end
60
+ end
61
+
62
+ # For compatibility with previous versions.
63
+ Build_ex = BuildEx
64
+
65
+ # Exception, thrown if unknown target type is detected.
66
+ class UnsupportedTargetTypeEx < Ex
67
+ def initialize( target_class, target_type )
68
+ super( "Unsupported target type '#{target_type}'" +
69
+ " in '#{target_class}'" )
70
+ end
71
+ end
72
+
73
+ # For compatibility with previous versions.
74
+ Unsupported_target_type_ex = UnsupportedTargetTypeEx
75
+
76
+ # Exception, thrown if no target object is found for given alias.
77
+ class TargetUnknownEx < Ex
78
+ def initialize( target_name )
79
+ super( "Target unknown for: " + target_name )
80
+ end
81
+ end
82
+
83
+ # For compatibility with previous versions.
84
+ Target_unknown_ex = TargetUnknownEx
85
+
86
+ # Exception, thrown if value conflict for global options such as
87
+ # runtime_mode, rtl_mode, etc is detected
88
+ class GlobalOptionConflictEx < Ex
89
+ # [_a_name_] Option name.
90
+ # [_a_current_] Current option value.
91
+ # [_a_current_owner_] Who was set current value.
92
+ # [_a_new_] New option value.
93
+ # [_a_new_owner_] Who tries to set current value.
94
+ def initialize(
95
+ a_name,
96
+ a_current,
97
+ a_current_owner,
98
+ a_new,
99
+ a_new_owner )
100
+
101
+ super( "Global option '#{a_name}' conflict detected! " +
102
+ "Current value '#{a_current}' set by '#{a_current_owner}'. " +
103
+ "New value '#{a_new}' required by '#{a_new_owner}'" )
104
+ end
105
+ end
106
+
107
+ # For compatibility with previous versions.
108
+ Global_option_conflict_ex = GlobalOptionConflictEx
109
+
110
+ # Exception, thrown if anyone tries to set invalid value to global options
111
+ # such as runtime_mode, rtl_mode, etc.
112
+ class GlobalOptionDisallowedValueEx < Ex
113
+ # [_a_name_] Option name.
114
+ # [_a_available_values_] Available values list. Should be Array of String.
115
+ # [_a_new_] New option value.
116
+ # [_a_new_owner_] Who tries to set new value.
117
+ def initialize(
118
+ a_name,
119
+ a_available_values,
120
+ a_new,
121
+ a_new_owner )
122
+
123
+ super( "Value '#{new}' required by '#{a_new_owner}' " +
124
+ "disallowed for global option '#{a_name}'! " +
125
+ "Allowed values are: #{a_available_values.join(' ')}" )
126
+ end
127
+ end
128
+
129
+ # For compatibility with previous versions.
130
+ Global_option_disallowed_value_ex = GlobalOptionDisallowedValueEx
131
+
132
+ # Exception, thrown if some mode is not supported by the toolset.
133
+ class UnsupportedModeEx < Ex
134
+ def initialize( msg )
135
+ super( msg )
136
+ end
137
+ end
138
+
139
+ # For compatibility with previous versions.
140
+ Unsupported_mode_ex = UnsupportedModeEx
141
+
142
+ # Exception, thrown if some dependency file is missing.
143
+ class MissingDependFileEx < Ex
144
+ def initialize( missing_file, depend_for )
145
+ super( "File '#{missing_file}' required by '#{depend_for}' " +
146
+ "missing" )
147
+ end
148
+ end
149
+
150
+ # For compatibility with previous versions.
151
+ Missing_depend_file_ex = MissingDependFileEx
152
+
153
+ # Exception, thrown if some value is invalid in current context.
154
+ class InvalidValueEx < Ex
155
+ def initialize( msg )
156
+ super( msg )
157
+ end
158
+ end
159
+
160
+ # For compatibility with previous versions.
161
+ Invalid_value_ex = InvalidValueEx
162
+
163
+ end
164
+
165
+ load File.dirname( __FILE__ ) + '/compat.rb'
@@ -1,146 +1,146 @@
1
- #--
2
- # Copyright (c) 1996-2004, Yauheni Akhotnikau
3
- # Copyright (c) 2004-2006, JSC Intervale
4
- # Copyright (c) 2006, The Mxx_ru Project
5
- # All rights reserved.
6
- #
7
- # Redistribution and use in source and binary forms, with or without modification,
8
- # are permitted provided that the following conditions are met:
9
- #
10
- # 1. Redistributions of source code must retain the above copyright notice,
11
- # this list of conditions and the following disclaimer.
12
- # 2. Redistributions in binary form must reproduce the above copyright notice,
13
- # this list of conditions and the following disclaimer in the documentation
14
- # and/or other materials provided with the distribution.
15
- # 3. The name of the author may not be used to endorse or promote products derived
16
- # from this software without specific prior written permission.
17
- #
18
- # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
19
- # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
20
- # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
21
- # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
- # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23
- # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
- # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25
- # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26
- # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
- #++
28
-
29
- require 'mxx_ru/abstract_target.rb'
30
-
31
- module MxxRu
32
-
33
- # A Generator, which allows to define simple make rules in a project.
34
- #
35
- # For example, if it's needed to get from ddl file two other files,
36
- # cpp and hpp, using typegen program, it should be done like that:
37
- # generator( MxxRu::MakestyleGenerator.new(
38
- # [ "myfile.cpp", "myfile.hpp" ],
39
- # [ "myfile.ddl" ],
40
- # [ "typegen --from myfile.ddl --cpp myfile.cpp --header myfile.hpp" ] ) )
41
- #
42
- # NOTE: For C++ projects current value of sources_root isn't taken into account.
43
- class MakestyleGenerator < AbstractGenerator
44
- # File names list, which should be built by given generator.
45
- attr_reader :target_files
46
-
47
- # File names list, result files depends from.
48
- attr_reader :dependencies
49
-
50
- # Command list, which should be ran in a sequence to get result files.
51
- attr_reader :build_cmds
52
-
53
- # Command list, which should be ran in a sequence to remove result files.
54
- #
55
- # If this list is empty, removal of result files would occur on clean
56
- # operation.
57
- attr_reader :clean_cmds
58
-
59
- # Constructor.
60
- #
61
- # [_a_target_files_] Result files list.
62
- # [_a_dependencies_] Dependencies list.
63
- # [_a_build_cmds_] Command list, which should be ran in a sequence to get
64
- # result files.
65
- # [_a_clean_cmds_] Command list, which should be ran in a sequence to remove
66
- # result files.
67
- #
68
- # NOTE: Single values may be defined as a strings instead of vectors. For
69
- # example:
70
- # MxxRu::MakestyleGenerator.new( "myfile.cpp", "myfile.ddl",
71
- # [ "typegen --from myfile.ddl --to myfile.cpp" ] )
72
- # It's the same as:
73
- # MxxRu::MakestyleGenerator.new( [ "myfile.cpp" ], [ "myfile.ddl" ],
74
- # "typegen --from myfile.ddl --to myfile.cpp" )
75
- #
76
- def initialize(
77
- a_target_files,
78
- a_dependencies,
79
- a_build_cmds,
80
- a_clean_cmds = Array.new )
81
-
82
- @target_files = make_array( a_target_files )
83
- @dependencies = make_array( a_dependencies )
84
- @build_cmds = make_array( a_build_cmds )
85
- @clean_cmds = make_array( a_clean_cmds )
86
- end
87
-
88
- # Perform the build of result files.
89
- #
90
- # NOTE: _target_ argument is ignored.
91
- def build( target )
92
- need_build = false
93
-
94
- # Checking all result files. If one of them is obsolete, performing rebuild.
95
- index = 0
96
- while !need_build && index != @target_files.size
97
- if TargetState::EXISTS != TargetState.detect(
98
- @target_files[ index ], @dependencies ).state
99
- need_build = true
100
- else
101
- index += 1
102
- end
103
- end
104
-
105
- if need_build
106
- # It's required to run all commands to build target.
107
- AbstractTarget.run(
108
- @build_cmds,
109
- [],
110
- "building #{@target_files.join(', ')}" )
111
- end
112
- end
113
-
114
- # Perform the cleanup of result files.
115
- #
116
- # NOTE: _target_ argument is ignored.
117
- def clean( target )
118
- # If cleanup commands weren't set, deleting result files.
119
- # Otherwise, it's required to run all commands in a sequence,
120
- # ignoring return codes.
121
- if 0 != @clean_cmds.size
122
- @clean_cmds.each do |c|
123
- system( c )
124
- end
125
- else
126
- @target_files.each do |f|
127
- Util.delete_file( f )
128
- end
129
- end
130
- end
131
-
132
- protected
133
- # Conversion of single object into a vector, which contains that object.
134
- # If source object is a vector, it's returned without any operations on it.
135
- def make_array( a_object )
136
- if a_object.instance_of? Array
137
- return a_object
138
- end
139
-
140
- return [ a_object ]
141
- end
142
- end
143
-
144
- # For compatibility with previous versions.
145
- Makestyle_generator = MakestyleGenerator
146
- end
1
+ #--
2
+ # Copyright (c) 1996-2004, Yauheni Akhotnikau
3
+ # Copyright (c) 2004-2006, JSC Intervale
4
+ # Copyright (c) 2006, The Mxx_ru Project
5
+ # All rights reserved.
6
+ #
7
+ # Redistribution and use in source and binary forms, with or without modification,
8
+ # are permitted provided that the following conditions are met:
9
+ #
10
+ # 1. Redistributions of source code must retain the above copyright notice,
11
+ # this list of conditions and the following disclaimer.
12
+ # 2. Redistributions in binary form must reproduce the above copyright notice,
13
+ # this list of conditions and the following disclaimer in the documentation
14
+ # and/or other materials provided with the distribution.
15
+ # 3. The name of the author may not be used to endorse or promote products derived
16
+ # from this software without specific prior written permission.
17
+ #
18
+ # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
19
+ # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
20
+ # AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE
21
+ # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22
+ # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23
+ # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24
+ # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25
+ # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
26
+ # ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
+ #++
28
+
29
+ require 'mxx_ru/abstract_target.rb'
30
+
31
+ module MxxRu
32
+
33
+ # A Generator, which allows to define simple make rules in a project.
34
+ #
35
+ # For example, if it's needed to get from ddl file two other files,
36
+ # cpp and hpp, using typegen program, it should be done like that:
37
+ # generator( MxxRu::MakestyleGenerator.new(
38
+ # [ "myfile.cpp", "myfile.hpp" ],
39
+ # [ "myfile.ddl" ],
40
+ # [ "typegen --from myfile.ddl --cpp myfile.cpp --header myfile.hpp" ] ) )
41
+ #
42
+ # NOTE: For C++ projects current value of sources_root isn't taken into account.
43
+ class MakestyleGenerator < AbstractGenerator
44
+ # File names list, which should be built by given generator.
45
+ attr_reader :target_files
46
+
47
+ # File names list, result files depends from.
48
+ attr_reader :dependencies
49
+
50
+ # Command list, which should be ran in a sequence to get result files.
51
+ attr_reader :build_cmds
52
+
53
+ # Command list, which should be ran in a sequence to remove result files.
54
+ #
55
+ # If this list is empty, removal of result files would occur on clean
56
+ # operation.
57
+ attr_reader :clean_cmds
58
+
59
+ # Constructor.
60
+ #
61
+ # [_a_target_files_] Result files list.
62
+ # [_a_dependencies_] Dependencies list.
63
+ # [_a_build_cmds_] Command list, which should be ran in a sequence to get
64
+ # result files.
65
+ # [_a_clean_cmds_] Command list, which should be ran in a sequence to remove
66
+ # result files.
67
+ #
68
+ # NOTE: Single values may be defined as a strings instead of vectors. For
69
+ # example:
70
+ # MxxRu::MakestyleGenerator.new( "myfile.cpp", "myfile.ddl",
71
+ # [ "typegen --from myfile.ddl --to myfile.cpp" ] )
72
+ # It's the same as:
73
+ # MxxRu::MakestyleGenerator.new( [ "myfile.cpp" ], [ "myfile.ddl" ],
74
+ # "typegen --from myfile.ddl --to myfile.cpp" )
75
+ #
76
+ def initialize(
77
+ a_target_files,
78
+ a_dependencies,
79
+ a_build_cmds,
80
+ a_clean_cmds = Array.new )
81
+
82
+ @target_files = make_array( a_target_files )
83
+ @dependencies = make_array( a_dependencies )
84
+ @build_cmds = make_array( a_build_cmds )
85
+ @clean_cmds = make_array( a_clean_cmds )
86
+ end
87
+
88
+ # Perform the build of result files.
89
+ #
90
+ # NOTE: _target_ argument is ignored.
91
+ def build( target )
92
+ need_build = false
93
+
94
+ # Checking all result files. If one of them is obsolete, performing rebuild.
95
+ index = 0
96
+ while !need_build && index != @target_files.size
97
+ if TargetState::EXISTS != TargetState.detect(
98
+ @target_files[ index ], @dependencies ).state
99
+ need_build = true
100
+ else
101
+ index += 1
102
+ end
103
+ end
104
+
105
+ if need_build
106
+ # It's required to run all commands to build target.
107
+ AbstractTarget.run(
108
+ @build_cmds,
109
+ [],
110
+ "building #{@target_files.join(', ')}" )
111
+ end
112
+ end
113
+
114
+ # Perform the cleanup of result files.
115
+ #
116
+ # NOTE: _target_ argument is ignored.
117
+ def clean( target )
118
+ # If cleanup commands weren't set, deleting result files.
119
+ # Otherwise, it's required to run all commands in a sequence,
120
+ # ignoring return codes.
121
+ if 0 != @clean_cmds.size
122
+ @clean_cmds.each do |c|
123
+ system( c )
124
+ end
125
+ else
126
+ @target_files.each do |f|
127
+ Util.delete_file( f )
128
+ end
129
+ end
130
+ end
131
+
132
+ protected
133
+ # Conversion of single object into a vector, which contains that object.
134
+ # If source object is a vector, it's returned without any operations on it.
135
+ def make_array( a_object )
136
+ if a_object.instance_of? Array
137
+ return a_object
138
+ end
139
+
140
+ return [ a_object ]
141
+ end
142
+ end
143
+
144
+ # For compatibility with previous versions.
145
+ Makestyle_generator = MakestyleGenerator
146
+ end