zeroc-ice 3.7.0 → 3.7.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (684) hide show
  1. checksums.yaml +4 -4
  2. data/ICE_LICENSE +1 -1
  3. data/bin/slice2rb +1 -1
  4. data/ext/Communicator.cpp +72 -2
  5. data/ext/Communicator.h +1 -1
  6. data/ext/Config.h +11 -1
  7. data/ext/Connection.cpp +22 -2
  8. data/ext/Connection.h +4 -1
  9. data/ext/Endpoint.cpp +1 -1
  10. data/ext/Endpoint.h +1 -1
  11. data/ext/ImplicitContext.cpp +1 -1
  12. data/ext/ImplicitContext.h +1 -1
  13. data/ext/Init.cpp +1 -1
  14. data/ext/Logger.cpp +1 -1
  15. data/ext/Logger.h +1 -1
  16. data/ext/Operation.cpp +1 -1
  17. data/ext/Operation.h +1 -1
  18. data/ext/Properties.cpp +1 -1
  19. data/ext/Properties.h +1 -1
  20. data/ext/Proxy.cpp +70 -1
  21. data/ext/Proxy.h +1 -1
  22. data/ext/Slice.cpp +1 -1
  23. data/ext/Slice.h +1 -1
  24. data/ext/Types.cpp +21 -5
  25. data/ext/Types.h +1 -1
  26. data/ext/Util.cpp +1 -1
  27. data/ext/Util.h +1 -1
  28. data/ext/ValueFactoryManager.cpp +2 -2
  29. data/ext/ValueFactoryManager.h +2 -2
  30. data/ext/ice/cpp/include/Ice/Application.h +234 -76
  31. data/ext/ice/cpp/include/Ice/AsyncResult.h +77 -1
  32. data/ext/ice/cpp/include/Ice/AsyncResultF.h +1 -1
  33. data/ext/ice/cpp/include/Ice/BatchRequestInterceptor.h +35 -2
  34. data/ext/ice/cpp/include/Ice/BatchRequestQueueF.h +1 -1
  35. data/ext/ice/cpp/include/Ice/Buffer.h +1 -1
  36. data/ext/ice/cpp/include/Ice/CommunicatorAsync.h +43 -1
  37. data/ext/ice/cpp/include/Ice/Comparable.h +81 -1
  38. data/ext/ice/cpp/include/Ice/Config.h +8 -1
  39. data/ext/ice/cpp/include/Ice/ConnectionAsync.h +97 -1
  40. data/ext/ice/cpp/include/Ice/ConnectionIF.h +3 -1
  41. data/ext/ice/cpp/include/Ice/ConsoleUtil.h +1 -1
  42. data/ext/ice/cpp/include/Ice/DefaultValueFactory.h +1 -1
  43. data/ext/ice/cpp/include/Ice/DispatchInterceptor.h +17 -2
  44. data/ext/ice/cpp/include/Ice/Dispatcher.h +22 -2
  45. data/ext/ice/cpp/include/Ice/DynamicLibrary.h +1 -1
  46. data/ext/ice/cpp/include/Ice/DynamicLibraryF.h +1 -1
  47. data/ext/ice/cpp/include/Ice/Exception.h +57 -15
  48. data/ext/ice/cpp/include/Ice/ExceptionHelpers.h +19 -1
  49. data/ext/ice/cpp/include/Ice/FactoryTable.h +12 -2
  50. data/ext/ice/cpp/include/Ice/FactoryTableInit.h +1 -1
  51. data/ext/ice/cpp/include/Ice/Format.h +13 -14
  52. data/ext/ice/cpp/include/Ice/Functional.h +6 -1
  53. data/ext/ice/cpp/include/Ice/GCObject.h +1 -1
  54. data/ext/ice/cpp/include/Ice/Handle.h +1 -1
  55. data/ext/ice/cpp/include/Ice/Ice.h +1 -1
  56. data/ext/ice/cpp/include/Ice/IconvStringConverter.h +38 -3
  57. data/ext/ice/cpp/include/Ice/Incoming.h +15 -2
  58. data/ext/ice/cpp/include/Ice/IncomingAsync.h +37 -4
  59. data/ext/ice/cpp/include/Ice/IncomingAsyncF.h +1 -1
  60. data/ext/ice/cpp/include/Ice/Initialize.h +764 -98
  61. data/ext/ice/cpp/include/Ice/InputStream.h +637 -112
  62. data/ext/ice/cpp/include/Ice/InstanceF.h +1 -1
  63. data/ext/ice/cpp/include/Ice/InterfaceByValue.h +17 -1
  64. data/ext/ice/cpp/include/Ice/LocalObject.h +5 -1
  65. data/ext/ice/cpp/include/Ice/LocalObjectF.h +1 -1
  66. data/ext/ice/cpp/include/Ice/LoggerUtil.h +37 -6
  67. data/ext/ice/cpp/include/Ice/MetricsAdminI.h +3 -1
  68. data/ext/ice/cpp/include/Ice/MetricsFunctional.h +3 -1
  69. data/ext/ice/cpp/include/Ice/MetricsObserverI.h +3 -1
  70. data/ext/ice/cpp/include/Ice/NativePropertiesAdmin.h +46 -23
  71. data/ext/ice/cpp/include/Ice/Object.h +338 -47
  72. data/ext/ice/cpp/include/Ice/ObjectF.h +5 -1
  73. data/ext/ice/cpp/include/Ice/ObserverHelper.h +1 -1
  74. data/ext/ice/cpp/include/Ice/Optional.h +22 -6
  75. data/ext/ice/cpp/include/Ice/OutgoingAsync.h +15 -1
  76. data/ext/ice/cpp/include/Ice/OutgoingAsyncF.h +1 -1
  77. data/ext/ice/cpp/include/Ice/OutputStream.h +436 -92
  78. data/ext/ice/cpp/include/Ice/Protocol.h +31 -1
  79. data/ext/ice/cpp/include/Ice/Proxy.h +2244 -190
  80. data/ext/ice/cpp/include/Ice/ProxyF.h +3 -1
  81. data/ext/ice/cpp/include/Ice/ProxyFactoryF.h +1 -1
  82. data/ext/ice/cpp/include/Ice/ProxyHandle.h +10 -1
  83. data/ext/ice/cpp/include/Ice/ReferenceF.h +1 -1
  84. data/ext/ice/cpp/include/Ice/RegisterPlugins.h +67 -9
  85. data/ext/ice/cpp/include/Ice/RequestHandlerF.h +1 -1
  86. data/ext/ice/cpp/include/Ice/ResponseHandlerF.h +1 -1
  87. data/ext/ice/cpp/include/Ice/SHA1.h +1 -1
  88. data/ext/ice/cpp/include/Ice/ServantManagerF.h +1 -1
  89. data/ext/ice/cpp/include/Ice/Service.h +267 -138
  90. data/ext/ice/cpp/include/Ice/SliceChecksums.h +5 -1
  91. data/ext/ice/cpp/include/Ice/SlicedData.h +80 -33
  92. data/ext/ice/cpp/include/Ice/SlicedDataF.h +4 -1
  93. data/ext/ice/cpp/include/Ice/StreamHelpers.h +324 -116
  94. data/ext/ice/cpp/include/Ice/StringConverter.h +32 -1
  95. data/ext/ice/cpp/include/Ice/ThreadPoolF.h +1 -1
  96. data/ext/ice/cpp/include/Ice/UUID.h +2 -1
  97. data/ext/ice/cpp/include/Ice/UniquePtr.h +2 -2
  98. data/ext/ice/cpp/include/Ice/UniqueRef.h +6 -2
  99. data/ext/ice/cpp/include/Ice/UserExceptionFactory.h +6 -1
  100. data/ext/ice/cpp/include/Ice/Value.h +41 -1
  101. data/ext/ice/cpp/include/Ice/ValueF.h +3 -1
  102. data/ext/ice/cpp/include/IceSSL/Config.h +1 -1
  103. data/ext/ice/cpp/include/IceSSL/IceSSL.h +1 -1
  104. data/ext/ice/cpp/include/IceSSL/OpenSSL.h +75 -53
  105. data/ext/ice/cpp/include/IceSSL/Plugin.h +323 -218
  106. data/ext/ice/cpp/include/IceSSL/SChannel.h +34 -27
  107. data/ext/ice/cpp/include/IceSSL/SecureTransport.h +35 -28
  108. data/ext/ice/cpp/include/IceSSL/UWP.h +33 -24
  109. data/ext/ice/cpp/include/IceUtil/Atomic.h +1 -1
  110. data/ext/ice/cpp/include/IceUtil/Cond.h +1 -1
  111. data/ext/ice/cpp/include/IceUtil/Config.h +11 -3
  112. data/ext/ice/cpp/include/IceUtil/ConsoleUtil.h +1 -1
  113. data/ext/ice/cpp/include/IceUtil/CountDownLatch.h +1 -1
  114. data/ext/ice/cpp/include/IceUtil/CtrlCHandler.h +59 -31
  115. data/ext/ice/cpp/include/IceUtil/DisableWarnings.h +1 -1
  116. data/ext/ice/cpp/include/IceUtil/Exception.h +1 -1
  117. data/ext/ice/cpp/include/IceUtil/FileUtil.h +1 -1
  118. data/ext/ice/cpp/include/IceUtil/Functional.h +1 -1
  119. data/ext/ice/cpp/include/IceUtil/Handle.h +1 -1
  120. data/ext/ice/cpp/include/IceUtil/IceUtil.h +1 -1
  121. data/ext/ice/cpp/include/IceUtil/InputUtil.h +1 -1
  122. data/ext/ice/cpp/include/IceUtil/Iterator.h +1 -1
  123. data/ext/ice/cpp/include/IceUtil/Lock.h +1 -1
  124. data/ext/ice/cpp/include/IceUtil/Monitor.h +1 -1
  125. data/ext/ice/cpp/include/IceUtil/Mutex.h +2 -5
  126. data/ext/ice/cpp/include/IceUtil/MutexProtocol.h +1 -1
  127. data/ext/ice/cpp/include/IceUtil/MutexPtrLock.h +1 -1
  128. data/ext/ice/cpp/include/IceUtil/MutexPtrTryLock.h +1 -1
  129. data/ext/ice/cpp/include/IceUtil/Optional.h +95 -1
  130. data/ext/ice/cpp/include/IceUtil/Options.h +1 -1
  131. data/ext/ice/cpp/include/IceUtil/OutputUtil.h +1 -1
  132. data/ext/ice/cpp/include/IceUtil/PopDisableWarnings.h +1 -1
  133. data/ext/ice/cpp/include/IceUtil/PushDisableWarnings.h +1 -1
  134. data/ext/ice/cpp/include/IceUtil/Random.h +1 -1
  135. data/ext/ice/cpp/include/IceUtil/RecMutex.h +1 -1
  136. data/ext/ice/cpp/include/IceUtil/ResourceConfig.h +4 -4
  137. data/ext/ice/cpp/include/IceUtil/ScannerConfig.h +5 -3
  138. data/ext/ice/cpp/include/IceUtil/ScopedArray.h +1 -1
  139. data/ext/ice/cpp/include/IceUtil/Shared.h +1 -1
  140. data/ext/ice/cpp/include/IceUtil/StopWatch.h +1 -1
  141. data/ext/ice/cpp/include/IceUtil/StringConverter.h +106 -86
  142. data/ext/ice/cpp/include/IceUtil/StringUtil.h +1 -1
  143. data/ext/ice/cpp/include/IceUtil/Thread.h +1 -1
  144. data/ext/ice/cpp/include/IceUtil/ThreadException.h +1 -1
  145. data/ext/ice/cpp/include/IceUtil/Time.h +1 -1
  146. data/ext/ice/cpp/include/IceUtil/Timer.h +5 -1
  147. data/ext/ice/cpp/include/IceUtil/UUID.h +5 -1
  148. data/ext/ice/cpp/include/IceUtil/UndefSysMacros.h +1 -1
  149. data/ext/ice/cpp/include/generated/Ice/BuiltinSequences.h +80 -20
  150. data/ext/ice/cpp/include/generated/Ice/Communicator.h +927 -130
  151. data/ext/ice/cpp/include/generated/Ice/CommunicatorF.h +13 -5
  152. data/ext/ice/cpp/include/generated/Ice/Connection.h +990 -194
  153. data/ext/ice/cpp/include/generated/Ice/ConnectionF.h +21 -9
  154. data/ext/ice/cpp/include/generated/Ice/Current.h +180 -17
  155. data/ext/ice/cpp/include/generated/Ice/Endpoint.h +484 -118
  156. data/ext/ice/cpp/include/generated/Ice/EndpointF.h +41 -17
  157. data/ext/ice/cpp/include/generated/Ice/EndpointTypes.h +29 -3
  158. data/ext/ice/cpp/include/generated/Ice/FacetMap.h +11 -5
  159. data/ext/ice/cpp/include/generated/Ice/Identity.h +56 -7
  160. data/ext/ice/cpp/include/generated/Ice/ImplicitContext.h +150 -28
  161. data/ext/ice/cpp/include/generated/Ice/ImplicitContextF.h +13 -5
  162. data/ext/ice/cpp/include/generated/Ice/Instrumentation.h +629 -83
  163. data/ext/ice/cpp/include/generated/Ice/InstrumentationF.h +19 -7
  164. data/ext/ice/cpp/include/generated/Ice/LocalException.h +5104 -794
  165. data/ext/ice/cpp/include/generated/Ice/Locator.h +2222 -443
  166. data/ext/ice/cpp/include/generated/Ice/LocatorF.h +27 -9
  167. data/ext/ice/cpp/include/generated/Ice/Logger.h +104 -26
  168. data/ext/ice/cpp/include/generated/Ice/LoggerF.h +13 -5
  169. data/ext/ice/cpp/include/generated/Ice/Metrics.h +2534 -455
  170. data/ext/ice/cpp/include/generated/Ice/ObjectAdapter.h +1004 -126
  171. data/ext/ice/cpp/include/generated/Ice/ObjectAdapterF.h +13 -5
  172. data/ext/ice/cpp/include/generated/Ice/ObjectFactory.h +72 -12
  173. data/ext/ice/cpp/include/generated/Ice/Plugin.h +142 -28
  174. data/ext/ice/cpp/include/generated/Ice/PluginF.h +17 -7
  175. data/ext/ice/cpp/include/generated/Ice/Process.h +511 -71
  176. data/ext/ice/cpp/include/generated/Ice/ProcessF.h +18 -6
  177. data/ext/ice/cpp/include/generated/Ice/Properties.h +306 -58
  178. data/ext/ice/cpp/include/generated/Ice/PropertiesAdmin.h +737 -121
  179. data/ext/ice/cpp/include/generated/Ice/PropertiesF.h +22 -8
  180. data/ext/ice/cpp/include/generated/Ice/RemoteLogger.h +1526 -279
  181. data/ext/ice/cpp/include/generated/Ice/Router.h +1009 -198
  182. data/ext/ice/cpp/include/generated/Ice/RouterF.h +18 -6
  183. data/ext/ice/cpp/include/generated/Ice/ServantLocator.h +174 -18
  184. data/ext/ice/cpp/include/generated/Ice/ServantLocatorF.h +13 -5
  185. data/ext/ice/cpp/include/generated/Ice/SliceChecksumDict.h +13 -3
  186. data/ext/ice/cpp/include/generated/Ice/ValueFactory.h +177 -23
  187. data/ext/ice/cpp/include/generated/Ice/Version.h +43 -13
  188. data/ext/ice/cpp/include/generated/IceSSL/ConnectionInfo.h +71 -15
  189. data/ext/ice/cpp/include/generated/IceSSL/ConnectionInfoF.h +13 -5
  190. data/ext/ice/cpp/include/generated/IceSSL/EndpointInfo.h +39 -9
  191. data/ext/ice/cpp/src/Ice/ACM.cpp +12 -3
  192. data/ext/ice/cpp/src/Ice/ACM.h +1 -1
  193. data/ext/ice/cpp/src/Ice/ACMF.h +1 -1
  194. data/ext/ice/cpp/src/Ice/Acceptor.cpp +1 -1
  195. data/ext/ice/cpp/src/Ice/Acceptor.h +1 -1
  196. data/ext/ice/cpp/src/Ice/AcceptorF.h +1 -1
  197. data/ext/ice/cpp/src/Ice/ArgVector.cpp +1 -1
  198. data/ext/ice/cpp/src/Ice/ArgVector.h +1 -1
  199. data/ext/ice/cpp/src/Ice/AsyncResult.cpp +1 -1
  200. data/ext/ice/cpp/src/Ice/Base64.cpp +1 -1
  201. data/ext/ice/cpp/src/Ice/Base64.h +1 -1
  202. data/ext/ice/cpp/src/Ice/BatchRequestQueue.cpp +1 -1
  203. data/ext/ice/cpp/src/Ice/BatchRequestQueue.h +1 -1
  204. data/ext/ice/cpp/src/Ice/Buffer.cpp +1 -1
  205. data/ext/ice/cpp/src/Ice/BuiltinSequences.cpp +3 -3
  206. data/ext/ice/cpp/src/Ice/CollocatedRequestHandler.cpp +1 -1
  207. data/ext/ice/cpp/src/Ice/CollocatedRequestHandler.h +1 -1
  208. data/ext/ice/cpp/src/Ice/Communicator.cpp +6 -4
  209. data/ext/ice/cpp/src/Ice/CommunicatorF.cpp +3 -3
  210. data/ext/ice/cpp/src/Ice/CommunicatorI.cpp +34 -13
  211. data/ext/ice/cpp/src/Ice/CommunicatorI.h +10 -10
  212. data/ext/ice/cpp/src/Ice/Cond.cpp +1 -1
  213. data/ext/ice/cpp/src/Ice/ConnectRequestHandler.cpp +11 -6
  214. data/ext/ice/cpp/src/Ice/ConnectRequestHandler.h +1 -1
  215. data/ext/ice/cpp/src/Ice/ConnectRequestHandlerF.h +1 -1
  216. data/ext/ice/cpp/src/Ice/Connection.cpp +27 -11
  217. data/ext/ice/cpp/src/Ice/ConnectionF.cpp +3 -3
  218. data/ext/ice/cpp/src/Ice/ConnectionFactory.cpp +24 -19
  219. data/ext/ice/cpp/src/Ice/ConnectionFactory.h +1 -1
  220. data/ext/ice/cpp/src/Ice/ConnectionFactoryF.h +1 -1
  221. data/ext/ice/cpp/src/Ice/ConnectionI.cpp +45 -37
  222. data/ext/ice/cpp/src/Ice/ConnectionI.h +10 -8
  223. data/ext/ice/cpp/src/Ice/ConnectionRequestHandler.cpp +1 -1
  224. data/ext/ice/cpp/src/Ice/ConnectionRequestHandler.h +1 -1
  225. data/ext/ice/cpp/src/Ice/Connector.cpp +1 -1
  226. data/ext/ice/cpp/src/Ice/Connector.h +1 -1
  227. data/ext/ice/cpp/src/Ice/ConnectorF.h +1 -1
  228. data/ext/ice/cpp/src/Ice/CountDownLatch.cpp +1 -1
  229. data/ext/ice/cpp/src/Ice/Current.cpp +3 -3
  230. data/ext/ice/cpp/src/Ice/DefaultsAndOverrides.cpp +5 -7
  231. data/ext/ice/cpp/src/Ice/DefaultsAndOverrides.h +1 -1
  232. data/ext/ice/cpp/src/Ice/DefaultsAndOverridesF.h +1 -1
  233. data/ext/ice/cpp/src/Ice/DispatchInterceptor.cpp +1 -1
  234. data/ext/ice/cpp/src/Ice/DynamicLibrary.cpp +1 -1
  235. data/ext/ice/cpp/src/Ice/Endpoint.cpp +24 -10
  236. data/ext/ice/cpp/src/Ice/EndpointF.cpp +3 -3
  237. data/ext/ice/cpp/src/Ice/EndpointFactory.cpp +1 -1
  238. data/ext/ice/cpp/src/Ice/EndpointFactory.h +1 -1
  239. data/ext/ice/cpp/src/Ice/EndpointFactoryF.h +1 -1
  240. data/ext/ice/cpp/src/Ice/EndpointFactoryManager.cpp +7 -13
  241. data/ext/ice/cpp/src/Ice/EndpointFactoryManager.h +1 -1
  242. data/ext/ice/cpp/src/Ice/EndpointFactoryManagerF.h +1 -1
  243. data/ext/ice/cpp/src/Ice/EndpointI.cpp +2 -2
  244. data/ext/ice/cpp/src/Ice/EndpointI.h +5 -5
  245. data/ext/ice/cpp/src/Ice/EndpointIF.h +1 -1
  246. data/ext/ice/cpp/src/Ice/EndpointTypes.cpp +3 -3
  247. data/ext/ice/cpp/src/Ice/EventHandler.cpp +1 -1
  248. data/ext/ice/cpp/src/Ice/EventHandler.h +1 -1
  249. data/ext/ice/cpp/src/Ice/EventHandlerF.h +1 -1
  250. data/ext/ice/cpp/src/Ice/Exception.cpp +1 -1
  251. data/ext/ice/cpp/src/Ice/FacetMap.cpp +3 -3
  252. data/ext/ice/cpp/src/Ice/FactoryTable.cpp +1 -1
  253. data/ext/ice/cpp/src/Ice/FactoryTableInit.cpp +1 -1
  254. data/ext/ice/cpp/src/Ice/GCObject.cpp +1 -1
  255. data/ext/ice/cpp/src/Ice/HashUtil.h +1 -1
  256. data/ext/ice/cpp/src/Ice/HttpParser.cpp +1 -1
  257. data/ext/ice/cpp/src/Ice/HttpParser.h +1 -1
  258. data/ext/ice/cpp/src/Ice/IPEndpointI.cpp +24 -29
  259. data/ext/ice/cpp/src/Ice/IPEndpointI.h +5 -5
  260. data/ext/ice/cpp/src/Ice/IPEndpointIF.h +1 -1
  261. data/ext/ice/cpp/src/Ice/IconvStringConverter.cpp +1 -1
  262. data/ext/ice/cpp/src/Ice/Identity.cpp +3 -3
  263. data/ext/ice/cpp/src/Ice/ImplicitContext.cpp +6 -4
  264. data/ext/ice/cpp/src/Ice/ImplicitContextF.cpp +3 -3
  265. data/ext/ice/cpp/src/Ice/ImplicitContextI.cpp +2 -13
  266. data/ext/ice/cpp/src/Ice/ImplicitContextI.h +1 -1
  267. data/ext/ice/cpp/src/Ice/Incoming.cpp +1 -1
  268. data/ext/ice/cpp/src/Ice/IncomingAsync.cpp +1 -1
  269. data/ext/ice/cpp/src/Ice/IncomingRequest.h +1 -1
  270. data/ext/ice/cpp/src/Ice/Initialize.cpp +10 -16
  271. data/ext/ice/cpp/src/Ice/InputStream.cpp +1 -1
  272. data/ext/ice/cpp/src/Ice/Instance.cpp +13 -34
  273. data/ext/ice/cpp/src/Ice/Instance.h +1 -1
  274. data/ext/ice/cpp/src/Ice/Instrumentation.cpp +33 -13
  275. data/ext/ice/cpp/src/Ice/InstrumentationF.cpp +3 -3
  276. data/ext/ice/cpp/src/Ice/InstrumentationI.cpp +1 -1
  277. data/ext/ice/cpp/src/Ice/InstrumentationI.h +1 -1
  278. data/ext/ice/cpp/src/Ice/LocalException.cpp +279 -279
  279. data/ext/ice/cpp/src/Ice/LocalObject.cpp +1 -1
  280. data/ext/ice/cpp/src/Ice/Locator.cpp +287 -174
  281. data/ext/ice/cpp/src/Ice/LocatorF.cpp +3 -3
  282. data/ext/ice/cpp/src/Ice/LocatorInfo.cpp +4 -9
  283. data/ext/ice/cpp/src/Ice/LocatorInfo.h +1 -1
  284. data/ext/ice/cpp/src/Ice/LocatorInfoF.h +1 -1
  285. data/ext/ice/cpp/src/Ice/Logger.cpp +6 -4
  286. data/ext/ice/cpp/src/Ice/LoggerAdminI.cpp +1 -1
  287. data/ext/ice/cpp/src/Ice/LoggerAdminI.h +1 -1
  288. data/ext/ice/cpp/src/Ice/LoggerF.cpp +3 -3
  289. data/ext/ice/cpp/src/Ice/LoggerI.cpp +1 -1
  290. data/ext/ice/cpp/src/Ice/LoggerI.h +1 -1
  291. data/ext/ice/cpp/src/Ice/LoggerUtil.cpp +1 -1
  292. data/ext/ice/cpp/src/Ice/Metrics.cpp +297 -109
  293. data/ext/ice/cpp/src/Ice/MetricsAdminI.cpp +2 -7
  294. data/ext/ice/cpp/src/Ice/MetricsObserverI.cpp +1 -1
  295. data/ext/ice/cpp/src/Ice/Network.cpp +188 -225
  296. data/ext/ice/cpp/src/Ice/Network.h +3 -12
  297. data/ext/ice/cpp/src/Ice/NetworkF.h +1 -1
  298. data/ext/ice/cpp/src/Ice/NetworkProxy.cpp +1 -1
  299. data/ext/ice/cpp/src/Ice/NetworkProxy.h +1 -1
  300. data/ext/ice/cpp/src/Ice/NetworkProxyF.h +1 -1
  301. data/ext/ice/cpp/src/Ice/Object.cpp +7 -4
  302. data/ext/ice/cpp/src/Ice/ObjectAdapter.cpp +6 -4
  303. data/ext/ice/cpp/src/Ice/ObjectAdapterF.cpp +3 -3
  304. data/ext/ice/cpp/src/Ice/ObjectAdapterFactory.cpp +53 -19
  305. data/ext/ice/cpp/src/Ice/ObjectAdapterFactory.h +1 -1
  306. data/ext/ice/cpp/src/Ice/ObjectAdapterFactoryF.h +1 -1
  307. data/ext/ice/cpp/src/Ice/ObjectAdapterI.cpp +116 -150
  308. data/ext/ice/cpp/src/Ice/ObjectAdapterI.h +11 -11
  309. data/ext/ice/cpp/src/Ice/ObjectFactory.cpp +6 -4
  310. data/ext/ice/cpp/src/Ice/ObserverHelper.cpp +1 -1
  311. data/ext/ice/cpp/src/Ice/OpaqueEndpointI.cpp +25 -42
  312. data/ext/ice/cpp/src/Ice/OpaqueEndpointI.h +2 -2
  313. data/ext/ice/cpp/src/Ice/OutgoingAsync.cpp +1 -1
  314. data/ext/ice/cpp/src/Ice/OutputStream.cpp +1 -1
  315. data/ext/ice/cpp/src/Ice/Plugin.cpp +9 -5
  316. data/ext/ice/cpp/src/Ice/PluginF.cpp +3 -3
  317. data/ext/ice/cpp/src/Ice/PluginManagerI.cpp +15 -34
  318. data/ext/ice/cpp/src/Ice/PluginManagerI.h +3 -3
  319. data/ext/ice/cpp/src/Ice/Process.cpp +69 -40
  320. data/ext/ice/cpp/src/Ice/ProcessF.cpp +3 -3
  321. data/ext/ice/cpp/src/Ice/Properties.cpp +6 -4
  322. data/ext/ice/cpp/src/Ice/PropertiesAdmin.cpp +89 -54
  323. data/ext/ice/cpp/src/Ice/PropertiesAdminI.cpp +1 -1
  324. data/ext/ice/cpp/src/Ice/PropertiesAdminI.h +1 -1
  325. data/ext/ice/cpp/src/Ice/PropertiesF.cpp +3 -3
  326. data/ext/ice/cpp/src/Ice/PropertiesI.cpp +15 -21
  327. data/ext/ice/cpp/src/Ice/PropertiesI.h +10 -10
  328. data/ext/ice/cpp/src/Ice/PropertyNames.cpp +4 -2
  329. data/ext/ice/cpp/src/Ice/PropertyNames.h +2 -2
  330. data/ext/ice/cpp/src/Ice/Protocol.cpp +5 -13
  331. data/ext/ice/cpp/src/Ice/ProtocolInstance.cpp +1 -1
  332. data/ext/ice/cpp/src/Ice/ProtocolInstance.h +1 -1
  333. data/ext/ice/cpp/src/Ice/ProtocolInstanceF.h +1 -1
  334. data/ext/ice/cpp/src/Ice/ProtocolPluginFacade.cpp +1 -1
  335. data/ext/ice/cpp/src/Ice/ProtocolPluginFacade.h +1 -1
  336. data/ext/ice/cpp/src/Ice/ProtocolPluginFacadeF.h +1 -1
  337. data/ext/ice/cpp/src/Ice/Proxy.cpp +46 -1
  338. data/ext/ice/cpp/src/Ice/ProxyFactory.cpp +1 -1
  339. data/ext/ice/cpp/src/Ice/ProxyFactory.h +1 -1
  340. data/ext/ice/cpp/src/Ice/Reference.cpp +56 -6
  341. data/ext/ice/cpp/src/Ice/Reference.h +13 -2
  342. data/ext/ice/cpp/src/Ice/ReferenceFactory.cpp +51 -90
  343. data/ext/ice/cpp/src/Ice/ReferenceFactory.h +1 -1
  344. data/ext/ice/cpp/src/Ice/ReferenceFactoryF.h +1 -1
  345. data/ext/ice/cpp/src/Ice/RegisterPluginsInit.cpp +1 -1
  346. data/ext/ice/cpp/src/Ice/RegisterPluginsInit.h +1 -1
  347. data/ext/ice/cpp/src/Ice/RemoteLogger.cpp +203 -117
  348. data/ext/ice/cpp/src/Ice/ReplyStatus.h +1 -1
  349. data/ext/ice/cpp/src/Ice/RequestHandler.cpp +1 -1
  350. data/ext/ice/cpp/src/Ice/RequestHandler.h +1 -1
  351. data/ext/ice/cpp/src/Ice/RequestHandlerFactory.cpp +1 -1
  352. data/ext/ice/cpp/src/Ice/RequestHandlerFactory.h +1 -1
  353. data/ext/ice/cpp/src/Ice/ResponseHandler.cpp +1 -1
  354. data/ext/ice/cpp/src/Ice/ResponseHandler.h +1 -1
  355. data/ext/ice/cpp/src/Ice/RetryQueue.cpp +1 -1
  356. data/ext/ice/cpp/src/Ice/RetryQueue.h +1 -1
  357. data/ext/ice/cpp/src/Ice/RetryQueueF.h +1 -1
  358. data/ext/ice/cpp/src/Ice/Router.cpp +167 -89
  359. data/ext/ice/cpp/src/Ice/RouterF.cpp +3 -3
  360. data/ext/ice/cpp/src/Ice/RouterInfo.cpp +6 -28
  361. data/ext/ice/cpp/src/Ice/RouterInfo.h +1 -3
  362. data/ext/ice/cpp/src/Ice/RouterInfoF.h +1 -1
  363. data/ext/ice/cpp/src/Ice/SHA1.cpp +1 -1
  364. data/ext/ice/cpp/src/Ice/Selector.cpp +19 -26
  365. data/ext/ice/cpp/src/Ice/Selector.h +1 -1
  366. data/ext/ice/cpp/src/Ice/ServantLocator.cpp +6 -4
  367. data/ext/ice/cpp/src/Ice/ServantLocatorF.cpp +3 -3
  368. data/ext/ice/cpp/src/Ice/ServantManager.cpp +15 -31
  369. data/ext/ice/cpp/src/Ice/ServantManager.h +1 -1
  370. data/ext/ice/cpp/src/Ice/SharedContext.h +1 -1
  371. data/ext/ice/cpp/src/Ice/SliceChecksumDict.cpp +3 -3
  372. data/ext/ice/cpp/src/Ice/SliceChecksums.cpp +1 -1
  373. data/ext/ice/cpp/src/Ice/SlicedData.cpp +1 -1
  374. data/ext/ice/cpp/src/Ice/StreamSocket.cpp +32 -52
  375. data/ext/ice/cpp/src/Ice/StreamSocket.h +1 -1
  376. data/ext/ice/cpp/src/Ice/StringConverterPlugin.cpp +10 -1
  377. data/ext/ice/cpp/src/Ice/StringUtil.h +1 -1
  378. data/ext/ice/cpp/src/Ice/SysLoggerI.cpp +1 -1
  379. data/ext/ice/cpp/src/Ice/SysLoggerI.h +1 -1
  380. data/ext/ice/cpp/src/Ice/TcpAcceptor.cpp +5 -13
  381. data/ext/ice/cpp/src/Ice/TcpAcceptor.h +1 -1
  382. data/ext/ice/cpp/src/Ice/TcpConnector.cpp +1 -1
  383. data/ext/ice/cpp/src/Ice/TcpConnector.h +1 -1
  384. data/ext/ice/cpp/src/Ice/TcpEndpointI.cpp +8 -11
  385. data/ext/ice/cpp/src/Ice/TcpEndpointI.h +2 -2
  386. data/ext/ice/cpp/src/Ice/TcpTransceiver.cpp +1 -1
  387. data/ext/ice/cpp/src/Ice/TcpTransceiver.h +1 -1
  388. data/ext/ice/cpp/src/Ice/Thread.cpp +1 -1
  389. data/ext/ice/cpp/src/Ice/ThreadPool.cpp +13 -13
  390. data/ext/ice/cpp/src/Ice/ThreadPool.h +1 -1
  391. data/ext/ice/cpp/src/Ice/Timer.cpp +1 -1
  392. data/ext/ice/cpp/src/Ice/TraceLevels.cpp +1 -1
  393. data/ext/ice/cpp/src/Ice/TraceLevels.h +1 -1
  394. data/ext/ice/cpp/src/Ice/TraceLevelsF.h +1 -1
  395. data/ext/ice/cpp/src/Ice/TraceUtil.cpp +1 -1
  396. data/ext/ice/cpp/src/Ice/TraceUtil.h +1 -1
  397. data/ext/ice/cpp/src/Ice/Transceiver.cpp +1 -1
  398. data/ext/ice/cpp/src/Ice/Transceiver.h +1 -1
  399. data/ext/ice/cpp/src/Ice/TransceiverF.h +1 -1
  400. data/ext/ice/cpp/src/Ice/UdpConnector.cpp +1 -1
  401. data/ext/ice/cpp/src/Ice/UdpConnector.h +1 -1
  402. data/ext/ice/cpp/src/Ice/UdpEndpointI.cpp +19 -27
  403. data/ext/ice/cpp/src/Ice/UdpEndpointI.h +2 -2
  404. data/ext/ice/cpp/src/Ice/UdpTransceiver.cpp +17 -54
  405. data/ext/ice/cpp/src/Ice/UdpTransceiver.h +1 -1
  406. data/ext/ice/cpp/src/Ice/Value.cpp +1 -1
  407. data/ext/ice/cpp/src/Ice/ValueFactory.cpp +9 -5
  408. data/ext/ice/cpp/src/Ice/ValueFactoryManagerI.cpp +3 -6
  409. data/ext/ice/cpp/src/Ice/ValueFactoryManagerI.h +2 -2
  410. data/ext/ice/cpp/src/Ice/Version.cpp +3 -3
  411. data/ext/ice/cpp/src/Ice/VirtualShared.h +1 -1
  412. data/ext/ice/cpp/src/Ice/WSAcceptor.cpp +1 -1
  413. data/ext/ice/cpp/src/Ice/WSAcceptor.h +1 -1
  414. data/ext/ice/cpp/src/Ice/WSConnector.cpp +1 -1
  415. data/ext/ice/cpp/src/Ice/WSConnector.h +1 -1
  416. data/ext/ice/cpp/src/Ice/WSEndpoint.cpp +4 -5
  417. data/ext/ice/cpp/src/Ice/WSEndpoint.h +2 -2
  418. data/ext/ice/cpp/src/Ice/WSTransceiver.cpp +8 -9
  419. data/ext/ice/cpp/src/Ice/WSTransceiver.h +1 -1
  420. data/ext/ice/cpp/src/IceDiscovery/IceDiscovery.cpp +85 -27
  421. data/ext/ice/cpp/src/IceDiscovery/IceDiscovery.h +599 -113
  422. data/ext/ice/cpp/src/IceDiscovery/LocatorI.cpp +1 -1
  423. data/ext/ice/cpp/src/IceDiscovery/LocatorI.h +1 -1
  424. data/ext/ice/cpp/src/IceDiscovery/LookupI.cpp +1 -1
  425. data/ext/ice/cpp/src/IceDiscovery/LookupI.h +1 -1
  426. data/ext/ice/cpp/src/IceDiscovery/PluginI.cpp +1 -1
  427. data/ext/ice/cpp/src/IceDiscovery/PluginI.h +1 -1
  428. data/ext/ice/cpp/src/IceLocatorDiscovery/IceLocatorDiscovery.cpp +70 -24
  429. data/ext/ice/cpp/src/IceLocatorDiscovery/IceLocatorDiscovery.h +635 -69
  430. data/ext/ice/cpp/src/IceLocatorDiscovery/Plugin.h +1 -1
  431. data/ext/ice/cpp/src/IceLocatorDiscovery/PluginI.cpp +71 -9
  432. data/ext/ice/cpp/src/IceSSL/AcceptorI.cpp +2 -4
  433. data/ext/ice/cpp/src/IceSSL/AcceptorI.h +1 -1
  434. data/ext/ice/cpp/src/IceSSL/CertificateI.cpp +1 -1
  435. data/ext/ice/cpp/src/IceSSL/CertificateI.h +1 -1
  436. data/ext/ice/cpp/src/IceSSL/ConnectionInfo.cpp +6 -4
  437. data/ext/ice/cpp/src/IceSSL/ConnectionInfoF.cpp +3 -3
  438. data/ext/ice/cpp/src/IceSSL/ConnectorI.cpp +2 -4
  439. data/ext/ice/cpp/src/IceSSL/ConnectorI.h +1 -1
  440. data/ext/ice/cpp/src/IceSSL/EndpointI.cpp +2 -2
  441. data/ext/ice/cpp/src/IceSSL/EndpointI.h +2 -2
  442. data/ext/ice/cpp/src/IceSSL/EndpointInfo.cpp +6 -4
  443. data/ext/ice/cpp/src/IceSSL/Instance.cpp +1 -1
  444. data/ext/ice/cpp/src/IceSSL/Instance.h +1 -1
  445. data/ext/ice/cpp/src/IceSSL/InstanceF.h +1 -1
  446. data/ext/ice/cpp/src/IceSSL/OpenSSLCertificateI.cpp +1 -1
  447. data/ext/ice/cpp/src/IceSSL/OpenSSLEngine.cpp +1 -1
  448. data/ext/ice/cpp/src/IceSSL/OpenSSLEngine.h +1 -1
  449. data/ext/ice/cpp/src/IceSSL/OpenSSLEngineF.h +1 -1
  450. data/ext/ice/cpp/src/IceSSL/OpenSSLPluginI.cpp +1 -1
  451. data/ext/ice/cpp/src/IceSSL/OpenSSLTransceiverI.cpp +25 -62
  452. data/ext/ice/cpp/src/IceSSL/OpenSSLTransceiverI.h +1 -1
  453. data/ext/ice/cpp/src/IceSSL/OpenSSLUtil.cpp +1 -1
  454. data/ext/ice/cpp/src/IceSSL/OpenSSLUtil.h +1 -1
  455. data/ext/ice/cpp/src/IceSSL/PluginI.cpp +1 -1
  456. data/ext/ice/cpp/src/IceSSL/PluginI.h +1 -1
  457. data/ext/ice/cpp/src/IceSSL/RFC2253.cpp +1 -1
  458. data/ext/ice/cpp/src/IceSSL/RFC2253.h +1 -1
  459. data/ext/ice/cpp/src/IceSSL/SChannelCertificateI.cpp +1 -1
  460. data/ext/ice/cpp/src/IceSSL/SChannelEngine.cpp +1 -1
  461. data/ext/ice/cpp/src/IceSSL/SChannelEngine.h +1 -1
  462. data/ext/ice/cpp/src/IceSSL/SChannelEngineF.h +1 -1
  463. data/ext/ice/cpp/src/IceSSL/SChannelPluginI.cpp +1 -1
  464. data/ext/ice/cpp/src/IceSSL/SChannelTransceiverI.cpp +19 -27
  465. data/ext/ice/cpp/src/IceSSL/SChannelTransceiverI.h +1 -1
  466. data/ext/ice/cpp/src/IceSSL/SSLEngine.cpp +7 -16
  467. data/ext/ice/cpp/src/IceSSL/SSLEngine.h +1 -1
  468. data/ext/ice/cpp/src/IceSSL/SSLEngineF.h +1 -1
  469. data/ext/ice/cpp/src/IceSSL/SecureTransportCertificateI.cpp +1 -1
  470. data/ext/ice/cpp/src/IceSSL/SecureTransportEngine.cpp +1 -1
  471. data/ext/ice/cpp/src/IceSSL/SecureTransportEngine.h +1 -1
  472. data/ext/ice/cpp/src/IceSSL/SecureTransportEngineF.h +1 -1
  473. data/ext/ice/cpp/src/IceSSL/SecureTransportPluginI.cpp +1 -1
  474. data/ext/ice/cpp/src/IceSSL/SecureTransportTransceiverI.cpp +1 -1
  475. data/ext/ice/cpp/src/IceSSL/SecureTransportTransceiverI.h +1 -1
  476. data/ext/ice/cpp/src/IceSSL/SecureTransportUtil.cpp +7 -10
  477. data/ext/ice/cpp/src/IceSSL/SecureTransportUtil.h +1 -1
  478. data/ext/ice/cpp/src/IceSSL/TrustManager.cpp +4 -5
  479. data/ext/ice/cpp/src/IceSSL/TrustManager.h +1 -1
  480. data/ext/ice/cpp/src/IceSSL/TrustManagerF.h +1 -1
  481. data/ext/ice/cpp/src/IceSSL/UWPCertificateI.cpp +1 -1
  482. data/ext/ice/cpp/src/IceSSL/UWPEngine.cpp +1 -1
  483. data/ext/ice/cpp/src/IceSSL/UWPEngine.h +1 -1
  484. data/ext/ice/cpp/src/IceSSL/UWPEngineF.h +1 -1
  485. data/ext/ice/cpp/src/IceSSL/UWPPluginI.cpp +1 -1
  486. data/ext/ice/cpp/src/IceSSL/UWPTransceiverI.cpp +1 -1
  487. data/ext/ice/cpp/src/IceSSL/UWPTransceiverI.h +1 -1
  488. data/ext/ice/cpp/src/IceSSL/Util.cpp +1 -1
  489. data/ext/ice/cpp/src/IceSSL/Util.h +1 -1
  490. data/ext/ice/cpp/src/IceUtil/ConsoleUtil.cpp +1 -1
  491. data/ext/ice/cpp/src/IceUtil/ConvertUTF.cpp +1 -1
  492. data/ext/ice/cpp/src/IceUtil/ConvertUTF.h +1 -1
  493. data/ext/ice/cpp/src/IceUtil/CtrlCHandler.cpp +1 -1
  494. data/ext/ice/cpp/src/IceUtil/FileUtil.cpp +5 -5
  495. data/ext/ice/cpp/src/IceUtil/InputUtil.cpp +1 -1
  496. data/ext/ice/cpp/src/IceUtil/MutexProtocol.cpp +1 -1
  497. data/ext/ice/cpp/src/IceUtil/Options.cpp +1 -1
  498. data/ext/ice/cpp/src/IceUtil/OutputUtil.cpp +1 -1
  499. data/ext/ice/cpp/src/IceUtil/Random.cpp +1 -1
  500. data/ext/ice/cpp/src/IceUtil/RecMutex.cpp +1 -5
  501. data/ext/ice/cpp/src/IceUtil/Shared.cpp +1 -1
  502. data/ext/ice/cpp/src/IceUtil/StringConverter.cpp +1 -1
  503. data/ext/ice/cpp/src/IceUtil/StringUtil.cpp +1 -1
  504. data/ext/ice/cpp/src/IceUtil/ThreadException.cpp +1 -1
  505. data/ext/ice/cpp/src/IceUtil/Time.cpp +1 -1
  506. data/ext/ice/cpp/src/IceUtil/UUID.cpp +3 -3
  507. data/ext/ice/cpp/src/IceUtil/Unicode.cpp +1 -1
  508. data/ext/ice/cpp/src/IceUtil/Unicode.h +1 -1
  509. data/ext/ice/cpp/src/IceUtil/UtilException.cpp +1 -1
  510. data/ext/ice/cpp/src/Slice/CPlusPlusUtil.cpp +160 -150
  511. data/ext/ice/cpp/src/Slice/CPlusPlusUtil.h +9 -8
  512. data/ext/ice/cpp/src/Slice/Checksum.cpp +1 -1
  513. data/ext/ice/cpp/src/Slice/Checksum.h +1 -1
  514. data/ext/ice/cpp/src/Slice/FileTracker.cpp +1 -1
  515. data/ext/ice/cpp/src/Slice/FileTracker.h +1 -1
  516. data/ext/ice/cpp/src/Slice/Grammar.cpp +567 -585
  517. data/ext/ice/cpp/src/Slice/Grammar.h +2 -2
  518. data/ext/ice/cpp/src/Slice/GrammarUtil.h +1 -1
  519. data/ext/ice/cpp/src/Slice/JavaUtil.cpp +131 -47
  520. data/ext/ice/cpp/src/Slice/JavaUtil.h +10 -5
  521. data/ext/ice/cpp/src/Slice/MD5.cpp +1 -1
  522. data/ext/ice/cpp/src/Slice/MD5.h +1 -1
  523. data/ext/ice/cpp/src/Slice/PHPUtil.cpp +1 -1
  524. data/ext/ice/cpp/src/Slice/PHPUtil.h +1 -1
  525. data/ext/ice/cpp/src/Slice/Parser.cpp +383 -101
  526. data/ext/ice/cpp/src/Slice/Parser.h +40 -3
  527. data/ext/ice/cpp/src/Slice/Preprocessor.cpp +2 -1
  528. data/ext/ice/cpp/src/Slice/Preprocessor.h +2 -2
  529. data/ext/ice/cpp/src/Slice/Python.cpp +7 -15
  530. data/ext/ice/cpp/src/Slice/PythonUtil.cpp +66 -9
  531. data/ext/ice/cpp/src/Slice/PythonUtil.h +2 -2
  532. data/ext/ice/cpp/src/Slice/Ruby.cpp +1 -1
  533. data/ext/ice/cpp/src/Slice/RubyUtil.cpp +2 -2
  534. data/ext/ice/cpp/src/Slice/RubyUtil.h +1 -1
  535. data/ext/ice/cpp/src/Slice/Scanner.cpp +214 -135
  536. data/ext/ice/cpp/src/Slice/SliceUtil.cpp +1 -1
  537. data/ext/ice/cpp/src/Slice/StringLiteralUtil.cpp +99 -17
  538. data/ext/ice/cpp/src/Slice/Util.h +5 -4
  539. data/ice.gemspec +2 -2
  540. data/lib/Glacier2.rb +1 -1
  541. data/lib/Glacier2/Metrics.rb +2 -2
  542. data/lib/Glacier2/PermissionsVerifier.rb +2 -2
  543. data/lib/Glacier2/PermissionsVerifierF.rb +2 -2
  544. data/lib/Glacier2/Router.rb +2 -2
  545. data/lib/Glacier2/RouterF.rb +2 -2
  546. data/lib/Glacier2/SSLInfo.rb +2 -2
  547. data/lib/Glacier2/Session.rb +2 -2
  548. data/lib/Ice.rb +2 -2
  549. data/lib/Ice/BuiltinSequences.rb +2 -2
  550. data/lib/Ice/Communicator.rb +2 -2
  551. data/lib/Ice/CommunicatorF.rb +2 -2
  552. data/lib/Ice/Connection.rb +2 -2
  553. data/lib/Ice/ConnectionF.rb +2 -2
  554. data/lib/Ice/Current.rb +2 -2
  555. data/lib/Ice/Endpoint.rb +2 -2
  556. data/lib/Ice/EndpointF.rb +2 -2
  557. data/lib/Ice/EndpointTypes.rb +2 -2
  558. data/lib/Ice/FacetMap.rb +2 -2
  559. data/lib/Ice/Identity.rb +2 -2
  560. data/lib/Ice/ImplicitContext.rb +2 -2
  561. data/lib/Ice/ImplicitContextF.rb +2 -2
  562. data/lib/Ice/Instrumentation.rb +2 -2
  563. data/lib/Ice/InstrumentationF.rb +2 -2
  564. data/lib/Ice/LocalException.rb +2 -2
  565. data/lib/Ice/Locator.rb +2 -2
  566. data/lib/Ice/LocatorF.rb +2 -2
  567. data/lib/Ice/Logger.rb +2 -2
  568. data/lib/Ice/LoggerF.rb +2 -2
  569. data/lib/Ice/Metrics.rb +2 -2
  570. data/lib/Ice/ObjectAdapter.rb +2 -2
  571. data/lib/Ice/ObjectAdapterF.rb +2 -2
  572. data/lib/Ice/ObjectFactory.rb +2 -2
  573. data/lib/Ice/Plugin.rb +2 -2
  574. data/lib/Ice/PluginF.rb +2 -2
  575. data/lib/Ice/Process.rb +2 -2
  576. data/lib/Ice/ProcessF.rb +2 -2
  577. data/lib/Ice/Properties.rb +2 -2
  578. data/lib/Ice/PropertiesAdmin.rb +2 -2
  579. data/lib/Ice/PropertiesF.rb +2 -2
  580. data/lib/Ice/RemoteLogger.rb +2 -2
  581. data/lib/Ice/Router.rb +2 -2
  582. data/lib/Ice/RouterF.rb +2 -2
  583. data/lib/Ice/ServantLocator.rb +2 -2
  584. data/lib/Ice/ServantLocatorF.rb +2 -2
  585. data/lib/Ice/SliceChecksumDict.rb +2 -2
  586. data/lib/Ice/ValueFactory.rb +2 -2
  587. data/lib/Ice/Version.rb +2 -2
  588. data/lib/IceBox.rb +1 -1
  589. data/lib/IceBox/IceBox.rb +2 -2
  590. data/lib/IceGrid.rb +1 -1
  591. data/lib/IceGrid/Admin.rb +2 -2
  592. data/lib/IceGrid/Descriptor.rb +2 -2
  593. data/lib/IceGrid/Exception.rb +2 -2
  594. data/lib/IceGrid/FileParser.rb +2 -2
  595. data/lib/IceGrid/PluginFacade.rb +2 -2
  596. data/lib/IceGrid/Registry.rb +2 -2
  597. data/lib/IceGrid/Session.rb +2 -2
  598. data/lib/IceGrid/UserAccountMapper.rb +2 -2
  599. data/lib/IcePatch2.rb +1 -1
  600. data/lib/IcePatch2/FileInfo.rb +2 -2
  601. data/lib/IcePatch2/FileServer.rb +2 -2
  602. data/lib/IceStorm.rb +1 -1
  603. data/lib/IceStorm/IceStorm.rb +2 -2
  604. data/lib/IceStorm/Metrics.rb +2 -2
  605. data/slice/Glacier2/Metrics.ice +2 -2
  606. data/slice/Glacier2/PermissionsVerifier.ice +2 -2
  607. data/slice/Glacier2/PermissionsVerifierF.ice +2 -2
  608. data/slice/Glacier2/Router.ice +2 -2
  609. data/slice/Glacier2/RouterF.ice +2 -2
  610. data/slice/Glacier2/SSLInfo.ice +2 -2
  611. data/slice/Glacier2/Session.ice +2 -2
  612. data/slice/Ice/BuiltinSequences.ice +2 -2
  613. data/slice/Ice/Communicator.ice +66 -73
  614. data/slice/Ice/CommunicatorF.ice +2 -2
  615. data/slice/Ice/Connection.ice +47 -17
  616. data/slice/Ice/ConnectionF.ice +2 -2
  617. data/slice/Ice/Current.ice +4 -5
  618. data/slice/Ice/Endpoint.ice +16 -16
  619. data/slice/Ice/EndpointF.ice +2 -2
  620. data/slice/Ice/EndpointTypes.ice +2 -2
  621. data/slice/Ice/FacetMap.ice +2 -2
  622. data/slice/Ice/Identity.ice +2 -2
  623. data/slice/Ice/ImplicitContext.ice +6 -6
  624. data/slice/Ice/ImplicitContextF.ice +2 -2
  625. data/slice/Ice/Instrumentation.ice +2 -2
  626. data/slice/Ice/InstrumentationF.ice +2 -2
  627. data/slice/Ice/LocalException.ice +2 -2
  628. data/slice/Ice/Locator.ice +3 -3
  629. data/slice/Ice/LocatorF.ice +2 -2
  630. data/slice/Ice/Logger.ice +2 -2
  631. data/slice/Ice/LoggerF.ice +2 -2
  632. data/slice/Ice/Metrics.ice +2 -2
  633. data/slice/Ice/ObjectAdapter.ice +10 -10
  634. data/slice/Ice/ObjectAdapterF.ice +2 -2
  635. data/slice/Ice/ObjectFactory.ice +3 -3
  636. data/slice/Ice/Plugin.ice +4 -4
  637. data/slice/Ice/PluginF.ice +2 -2
  638. data/slice/Ice/Process.ice +2 -2
  639. data/slice/Ice/ProcessF.ice +2 -2
  640. data/slice/Ice/Properties.ice +11 -11
  641. data/slice/Ice/PropertiesAdmin.ice +2 -2
  642. data/slice/Ice/PropertiesF.ice +2 -2
  643. data/slice/Ice/RemoteLogger.ice +12 -23
  644. data/slice/Ice/Router.ice +2 -2
  645. data/slice/Ice/RouterF.ice +2 -2
  646. data/slice/Ice/ServantLocator.ice +2 -2
  647. data/slice/Ice/ServantLocatorF.ice +2 -2
  648. data/slice/Ice/SliceChecksumDict.ice +2 -2
  649. data/slice/Ice/ValueFactory.ice +14 -16
  650. data/slice/Ice/Version.ice +2 -2
  651. data/slice/IceBT/ConnectionInfo.ice +2 -2
  652. data/slice/IceBT/EndpointInfo.ice +2 -2
  653. data/slice/IceBT/Types.ice +2 -2
  654. data/slice/IceBox/IceBox.ice +3 -4
  655. data/slice/IceDiscovery/IceDiscovery.ice +2 -2
  656. data/slice/IceGrid/Admin.ice +2 -2
  657. data/slice/IceGrid/Descriptor.ice +2 -2
  658. data/slice/IceGrid/Exception.ice +2 -2
  659. data/slice/IceGrid/FileParser.ice +2 -2
  660. data/slice/IceGrid/PluginFacade.ice +6 -6
  661. data/slice/IceGrid/Registry.ice +2 -2
  662. data/slice/IceGrid/Session.ice +2 -2
  663. data/slice/IceGrid/UserAccountMapper.ice +2 -2
  664. data/slice/IceIAP/ConnectionInfo.ice +2 -2
  665. data/slice/IceIAP/EndpointInfo.ice +2 -2
  666. data/slice/IceLocatorDiscovery/IceLocatorDiscovery.ice +2 -2
  667. data/slice/IcePatch2/FileInfo.ice +2 -2
  668. data/slice/IcePatch2/FileServer.ice +2 -2
  669. data/slice/IceSSL/ConnectionInfo.ice +2 -2
  670. data/slice/IceSSL/ConnectionInfoF.ice +2 -2
  671. data/slice/IceSSL/EndpointInfo.ice +2 -2
  672. data/slice/IceStorm/IceStorm.ice +5 -6
  673. data/slice/IceStorm/Metrics.ice +2 -2
  674. metadata +3 -13
  675. data/BZIP2_LICENSE +0 -42
  676. data/ext/ice/bzip2/blocksort.c +0 -1094
  677. data/ext/ice/bzip2/bzlib.c +0 -1572
  678. data/ext/ice/bzip2/bzlib.h +0 -282
  679. data/ext/ice/bzip2/bzlib_private.h +0 -509
  680. data/ext/ice/bzip2/compress.c +0 -672
  681. data/ext/ice/bzip2/crctable.c +0 -104
  682. data/ext/ice/bzip2/decompress.c +0 -646
  683. data/ext/ice/bzip2/huffman.c +0 -205
  684. data/ext/ice/bzip2/randtable.c +0 -84
@@ -76,8 +76,8 @@ extern int slice_debug;
76
76
  ICE_IDEMPOTENT = 285,
77
77
  ICE_OPTIONAL = 286,
78
78
  ICE_VALUE = 287,
79
- ICE_SCOPE_DELIMITER = 288,
80
- ICE_IDENTIFIER = 289,
79
+ ICE_IDENTIFIER = 288,
80
+ ICE_SCOPED_IDENTIFIER = 289,
81
81
  ICE_STRING_LITERAL = 290,
82
82
  ICE_INTEGER_LITERAL = 291,
83
83
  ICE_FLOATING_POINT_LITERAL = 292,
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -431,6 +431,11 @@ private:
431
431
  result.push_back(s);
432
432
  continue;
433
433
  }
434
+ else if(s.substr(prefix.size(), pos - prefix.size()) == "package")
435
+ {
436
+ result.push_back(s);
437
+ continue;
438
+ }
434
439
 
435
440
  dc->warning(InvalidMetaData, cont->file(), cont->line(), "ignoring invalid metadata `" + s + "'");
436
441
  }
@@ -444,7 +449,8 @@ private:
444
449
  return result;
445
450
  }
446
451
 
447
- StringList validateType(const SyntaxTreeBasePtr& p, const StringList& metaData, const string& file, const string& line)
452
+ StringList validateType(const SyntaxTreeBasePtr& p, const StringList& metaData, const string& file,
453
+ const string& line)
448
454
  {
449
455
  const UnitPtr unit = p->unit();
450
456
  const DefinitionContextPtr dc = unit->findDefinitionContext(file);
@@ -520,6 +526,18 @@ private:
520
526
  dc->warning(InvalidMetaData, file, line, "ignoring invalid metadata `" + *i + "'");
521
527
  }
522
528
  }
529
+ else if(i->find("java:package:") == 0)
530
+ {
531
+ ModulePtr m = ModulePtr::dynamicCast(p);
532
+ if(m && UnitPtr::dynamicCast(m->container()))
533
+ {
534
+ newMetaData.push_back(*i);
535
+ }
536
+ else
537
+ {
538
+ dc->warning(InvalidMetaData, file, line, "ignoring invalid metadata `" + *i + "'");
539
+ }
540
+ }
523
541
  else
524
542
  {
525
543
  newMetaData.push_back(*i);
@@ -528,7 +546,8 @@ private:
528
546
  return newMetaData;
529
547
  }
530
548
 
531
- StringList validateGetSet(const SyntaxTreeBasePtr& p, const StringList& metaData, const string& file, const string& line)
549
+ StringList validateGetSet(const SyntaxTreeBasePtr& p, const StringList& metaData, const string& file,
550
+ const string& line)
532
551
  {
533
552
  const UnitPtr unit = p->unit();
534
553
  const DefinitionContextPtr dc= unit->findDefinitionContext(file);
@@ -771,7 +790,7 @@ Slice::JavaOutput::printHeader()
771
790
  static const char* header =
772
791
  "// **********************************************************************\n"
773
792
  "//\n"
774
- "// Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.\n"
793
+ "// Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.\n"
775
794
  "//\n"
776
795
  "// This copy of Ice is licensed to you under the terms described in the\n"
777
796
  "// ICE_LICENSE file included in this distribution.\n"
@@ -921,25 +940,51 @@ Slice::JavaCompatGenerator::convertScopedName(const string& scoped, const string
921
940
  string
922
941
  Slice::JavaCompatGenerator::getPackagePrefix(const ContainedPtr& cont) const
923
942
  {
924
- UnitPtr unit = cont->container()->unit();
925
- string file = cont->file();
926
- assert(!file.empty());
927
-
928
- map<string, string>::const_iterator p = _filePackagePrefix.find(file);
929
- if(p != _filePackagePrefix.end())
943
+ //
944
+ // Traverse to the top-level module.
945
+ //
946
+ ModulePtr m;
947
+ ContainedPtr p = cont;
948
+ while(true)
930
949
  {
931
- return p->second;
950
+ if(ModulePtr::dynamicCast(p))
951
+ {
952
+ m = ModulePtr::dynamicCast(p);
953
+ }
954
+
955
+ ContainerPtr c = p->container();
956
+ p = ContainedPtr::dynamicCast(c); // This cast fails for Unit.
957
+ if(!p)
958
+ {
959
+ break;
960
+ }
932
961
  }
933
962
 
963
+ assert(m);
964
+
965
+ //
966
+ // The java:package metadata can be defined as global metadata or applied to a top-level module.
967
+ // We check for the metadata at the top-level module first and then fall back to the global scope.
968
+ //
934
969
  static const string prefix = "java:package:";
935
- DefinitionContextPtr dc = unit->findDefinitionContext(file);
936
- assert(dc);
937
- string q = dc->findMetaData(prefix);
970
+
971
+ string q;
972
+ if(!m->findMetaData(prefix, q))
973
+ {
974
+ UnitPtr unit = cont->unit();
975
+ string file = cont->file();
976
+ assert(!file.empty());
977
+
978
+ DefinitionContextPtr dc = unit->findDefinitionContext(file);
979
+ assert(dc);
980
+ q = dc->findMetaData(prefix);
981
+ }
982
+
938
983
  if(!q.empty())
939
984
  {
940
985
  q = q.substr(prefix.size());
941
986
  }
942
- _filePackagePrefix[file] = q;
987
+
943
988
  return q;
944
989
  }
945
990
 
@@ -963,6 +1008,16 @@ Slice::JavaCompatGenerator::getPackage(const ContainedPtr& cont) const
963
1008
  return scope;
964
1009
  }
965
1010
 
1011
+ string
1012
+ Slice::JavaCompatGenerator::getAbsolute(const std::string& type, const std::string& package) const
1013
+ {
1014
+ if(type.find(".") != string::npos && type.find(package) == 0 && type.find(".", package.size() + 1) == string::npos)
1015
+ {
1016
+ return type.substr(package.size() + 1);
1017
+ }
1018
+ return type;
1019
+ }
1020
+
966
1021
  string
967
1022
  Slice::JavaCompatGenerator::getAbsolute(const ContainedPtr& cont,
968
1023
  const string& package,
@@ -3365,25 +3420,51 @@ Slice::JavaGenerator::convertScopedName(const string& scoped, const string& pref
3365
3420
  string
3366
3421
  Slice::JavaGenerator::getPackagePrefix(const ContainedPtr& cont) const
3367
3422
  {
3368
- UnitPtr unit = cont->container()->unit();
3369
- string file = cont->file();
3370
- assert(!file.empty());
3371
-
3372
- map<string, string>::const_iterator p = _filePackagePrefix.find(file);
3373
- if(p != _filePackagePrefix.end())
3423
+ //
3424
+ // Traverse to the top-level module.
3425
+ //
3426
+ ModulePtr m;
3427
+ ContainedPtr p = cont;
3428
+ while(true)
3374
3429
  {
3375
- return p->second;
3430
+ if(ModulePtr::dynamicCast(p))
3431
+ {
3432
+ m = ModulePtr::dynamicCast(p);
3433
+ }
3434
+
3435
+ ContainerPtr c = p->container();
3436
+ p = ContainedPtr::dynamicCast(c); // This cast fails for Unit.
3437
+ if(!p)
3438
+ {
3439
+ break;
3440
+ }
3376
3441
  }
3377
3442
 
3443
+ assert(m);
3444
+
3445
+ //
3446
+ // The java:package metadata can be defined as global metadata or applied to a top-level module.
3447
+ // We check for the metadata at the top-level module first and then fall back to the global scope.
3448
+ //
3378
3449
  static const string prefix = "java:package:";
3379
- DefinitionContextPtr dc = unit->findDefinitionContext(file);
3380
- assert(dc);
3381
- string q = dc->findMetaData(prefix);
3450
+
3451
+ string q;
3452
+ if(!m->findMetaData(prefix, q))
3453
+ {
3454
+ UnitPtr unit = cont->unit();
3455
+ string file = cont->file();
3456
+ assert(!file.empty());
3457
+
3458
+ DefinitionContextPtr dc = unit->findDefinitionContext(file);
3459
+ assert(dc);
3460
+ q = dc->findMetaData(prefix);
3461
+ }
3462
+
3382
3463
  if(!q.empty())
3383
3464
  {
3384
3465
  q = q.substr(prefix.size());
3385
3466
  }
3386
- _filePackagePrefix[file] = q;
3467
+
3387
3468
  return q;
3388
3469
  }
3389
3470
 
@@ -3407,6 +3488,16 @@ Slice::JavaGenerator::getPackage(const ContainedPtr& cont) const
3407
3488
  return scope;
3408
3489
  }
3409
3490
 
3491
+ string
3492
+ Slice::JavaGenerator::getAbsolute(const std::string& type, const std::string& package) const
3493
+ {
3494
+ if(type.find(".") != string::npos && type.find(package) == 0 && type.find(".", package.size() + 1) == string::npos)
3495
+ {
3496
+ return type.substr(package.size() + 1);
3497
+ }
3498
+ return type;
3499
+ }
3500
+
3410
3501
  string
3411
3502
  Slice::JavaGenerator::getAbsolute(const ContainedPtr& cont,
3412
3503
  const string& package,
@@ -3443,11 +3534,11 @@ Slice::JavaGenerator::getStaticId(const TypePtr& type, const string& package) co
3443
3534
 
3444
3535
  if(b && b->kind() == Builtin::KindObject)
3445
3536
  {
3446
- return "com.zeroc.Ice.Object.ice_staticId()";
3537
+ return getAbsolute("com.zeroc.Ice.Object", package) + ".ice_staticId()";
3447
3538
  }
3448
3539
  else if(b && b->kind() == Builtin::KindValue)
3449
3540
  {
3450
- return "com.zeroc.Ice.Value.ice_staticId()";
3541
+ return getAbsolute("com.zeroc.Ice.Value", package) + ".ice_staticId()";
3451
3542
  }
3452
3543
  else
3453
3544
  {
@@ -3569,21 +3660,6 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3569
3660
  bool local) const
3570
3661
  {
3571
3662
  static const char* builtinTable[] =
3572
- {
3573
- "byte",
3574
- "boolean",
3575
- "short",
3576
- "int",
3577
- "long",
3578
- "float",
3579
- "double",
3580
- "String",
3581
- "com.zeroc.Ice.Value",
3582
- "com.zeroc.Ice.ObjectPrx",
3583
- "java.lang.Object",
3584
- "com.zeroc.Ice.Value"
3585
- };
3586
- static const char* builtinLocalTable[] =
3587
3663
  {
3588
3664
  "byte",
3589
3665
  "boolean",
@@ -3598,6 +3674,7 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3598
3674
  "java.lang.Object",
3599
3675
  "com.zeroc.Ice.Value"
3600
3676
  };
3677
+
3601
3678
  static const char* builtinOptionalTable[] =
3602
3679
  {
3603
3680
  "java.util.Optional<java.lang.Byte>",
@@ -3649,7 +3726,7 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3649
3726
  case Builtin::KindFloat:
3650
3727
  case Builtin::KindDouble:
3651
3728
  {
3652
- return builtinOptionalTable[builtin->kind()];
3729
+ return getAbsolute(builtinOptionalTable[builtin->kind()], package);
3653
3730
  }
3654
3731
  case Builtin::KindString:
3655
3732
  case Builtin::KindObject:
@@ -3663,7 +3740,14 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3663
3740
  }
3664
3741
  else
3665
3742
  {
3666
- return local ? builtinLocalTable[builtin->kind()] : builtinTable[builtin->kind()];
3743
+ if(!local && builtin->kind() == Builtin::KindObject)
3744
+ {
3745
+ return getAbsolute(builtinTable[Builtin::KindValue], package);
3746
+ }
3747
+ else
3748
+ {
3749
+ return getAbsolute(builtinTable[builtin->kind()], package);
3750
+ }
3667
3751
  }
3668
3752
  }
3669
3753
 
@@ -3678,7 +3762,7 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3678
3762
  {
3679
3763
  if(cl->isInterface() && !local)
3680
3764
  {
3681
- return "com.zeroc.Ice.Value";
3765
+ return getAbsolute("com.zeroc.Ice.Value", package);
3682
3766
  }
3683
3767
  else
3684
3768
  {
@@ -3697,7 +3781,7 @@ Slice::JavaGenerator::typeToString(const TypePtr& type,
3697
3781
  }
3698
3782
  else
3699
3783
  {
3700
- return "com.zeroc.Ice.ObjectPrx";
3784
+ return getAbsolute("com.zeroc.Ice.ObjectPrx", package);
3701
3785
  }
3702
3786
  }
3703
3787
 
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -98,7 +98,7 @@ protected:
98
98
  const std::string& = std::string()) const;
99
99
 
100
100
  //
101
- // Returns the package prefix for a give Slice file.
101
+ // Returns the package prefix of a Contained entity.
102
102
  //
103
103
  std::string getPackagePrefix(const ContainedPtr&) const;
104
104
 
@@ -107,6 +107,7 @@ protected:
107
107
  //
108
108
  std::string getPackage(const ContainedPtr&) const;
109
109
 
110
+ std::string getAbsolute(const std::string&, const std::string&) const;
110
111
  //
111
112
  // Returns the Java name for a Contained entity. If the optional
112
113
  // package argument matches the entity's package name, then the
@@ -222,7 +223,6 @@ private:
222
223
 
223
224
  std::string _dir;
224
225
  ::IceUtilInternal::Output* _out;
225
- mutable std::map<std::string, std::string> _filePackagePrefix;
226
226
  };
227
227
 
228
228
  class JavaGenerator : private ::IceUtil::noncopyable
@@ -264,7 +264,7 @@ protected:
264
264
  const std::string& = std::string()) const;
265
265
 
266
266
  //
267
- // Returns the package prefix for a give Slice file.
267
+ // Returns the package prefix of a Contained entity.
268
268
  //
269
269
  std::string getPackagePrefix(const ContainedPtr&) const;
270
270
 
@@ -273,6 +273,12 @@ protected:
273
273
  //
274
274
  std::string getPackage(const ContainedPtr&) const;
275
275
 
276
+ //
277
+ // Returns the Java type without a package if the package
278
+ // matches the current package
279
+ //
280
+ std::string getAbsolute(const std::string&, const std::string&) const;
281
+
276
282
  //
277
283
  // Returns the Java name for a Contained entity. If the optional
278
284
  // package argument matches the entity's package name, then the
@@ -390,7 +396,6 @@ private:
390
396
 
391
397
  std::string _dir;
392
398
  ::IceUtilInternal::Output* _out;
393
- mutable std::map<std::string, std::string> _filePackagePrefix;
394
399
  };
395
400
 
396
401
  }
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -1,6 +1,6 @@
1
1
  // **********************************************************************
2
2
  //
3
- // Copyright (c) 2003-2017 ZeroC, Inc. All rights reserved.
3
+ // Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.
4
4
  //
5
5
  // This copy of Ice is licensed to you under the terms described in the
6
6
  // ICE_LICENSE file included in this distribution.
@@ -279,6 +279,62 @@ Slice::DefinitionContext::initSuppressedWarnings()
279
279
  }
280
280
  }
281
281
 
282
+ // ----------------------------------------------------------------------
283
+ // Comment
284
+ // ----------------------------------------------------------------------
285
+
286
+ bool
287
+ Slice::Comment::isDeprecated() const
288
+ {
289
+ return _isDeprecated;
290
+ }
291
+
292
+ StringList
293
+ Slice::Comment::deprecated() const
294
+ {
295
+ return _deprecated;
296
+ }
297
+
298
+ StringList
299
+ Slice::Comment::overview() const
300
+ {
301
+ return _overview;
302
+ }
303
+
304
+ StringList
305
+ Slice::Comment::misc() const
306
+ {
307
+ return _misc;
308
+ }
309
+
310
+ StringList
311
+ Slice::Comment::seeAlso() const
312
+ {
313
+ return _seeAlso;
314
+ }
315
+
316
+ StringList
317
+ Slice::Comment::returns() const
318
+ {
319
+ return _returns;
320
+ }
321
+
322
+ map<string, StringList>
323
+ Slice::Comment::parameters() const
324
+ {
325
+ return _parameters;
326
+ }
327
+
328
+ map<string, StringList>
329
+ Slice::Comment::exceptions() const
330
+ {
331
+ return _exceptions;
332
+ }
333
+
334
+ Slice::Comment::Comment()
335
+ {
336
+ }
337
+
282
338
  // ----------------------------------------------------------------------
283
339
  // SyntaxTreeBase
284
340
  // ----------------------------------------------------------------------
@@ -538,6 +594,330 @@ Slice::Contained::comment() const
538
594
  return _comment;
539
595
  }
540
596
 
597
+ namespace
598
+ {
599
+
600
+ void
601
+ trimLines(StringList& l)
602
+ {
603
+ //
604
+ // Remove empty trailing lines.
605
+ //
606
+ while(!l.empty() && l.back().empty())
607
+ {
608
+ l.pop_back();
609
+ }
610
+ }
611
+
612
+ StringList
613
+ splitComment(const string& c, bool stripMarkup)
614
+ {
615
+ string comment = c;
616
+
617
+ if(stripMarkup)
618
+ {
619
+ //
620
+ // Strip HTML markup and javadoc links.
621
+ //
622
+ string::size_type pos = 0;
623
+ do
624
+ {
625
+ pos = comment.find('<', pos);
626
+ if(pos != string::npos)
627
+ {
628
+ string::size_type endpos = comment.find('>', pos);
629
+ if(endpos == string::npos)
630
+ {
631
+ break;
632
+ }
633
+ comment.erase(pos, endpos - pos + 1);
634
+ }
635
+ }
636
+ while(pos != string::npos);
637
+
638
+ const string link = "{@link";
639
+ pos = 0;
640
+ do
641
+ {
642
+ pos = comment.find(link, pos);
643
+ if(pos != string::npos)
644
+ {
645
+ comment.erase(pos, link.size() + 1); // Erase trailing white space too.
646
+ string::size_type endpos = comment.find('}', pos);
647
+ if(endpos != string::npos)
648
+ {
649
+ string ident = comment.substr(pos, endpos - pos);
650
+ comment.erase(pos, endpos - pos + 1);
651
+
652
+ //
653
+ // Replace links of the form {@link Type#member} with "Type.member".
654
+ //
655
+ string::size_type hash = ident.find('#');
656
+ string rest;
657
+ if(hash != string::npos)
658
+ {
659
+ rest = ident.substr(hash + 1);
660
+ ident = ident.substr(0, hash);
661
+ if(!ident.empty())
662
+ {
663
+ if(!rest.empty())
664
+ {
665
+ ident += "." + rest;
666
+ }
667
+ }
668
+ else if(!rest.empty())
669
+ {
670
+ ident = rest;
671
+ }
672
+ }
673
+
674
+ comment.insert(pos, ident);
675
+ }
676
+ }
677
+ }
678
+ while(pos != string::npos);
679
+ }
680
+
681
+ StringList result;
682
+
683
+ string::size_type pos = 0;
684
+ string::size_type nextPos;
685
+ while((nextPos = comment.find_first_of('\n', pos)) != string::npos)
686
+ {
687
+ result.push_back(IceUtilInternal::trim(string(comment, pos, nextPos - pos)));
688
+ pos = nextPos + 1;
689
+ }
690
+ string lastLine = IceUtilInternal::trim(string(comment, pos));
691
+ if(!lastLine.empty())
692
+ {
693
+ result.push_back(lastLine);
694
+ }
695
+
696
+ trimLines(result);
697
+
698
+ return result;
699
+ }
700
+
701
+ bool
702
+ parseCommentLine(const string& l, const string& tag, bool namedTag, string& name, string& doc)
703
+ {
704
+ doc.clear();
705
+
706
+ if(l.find(tag) == 0)
707
+ {
708
+ const string ws = " \t";
709
+
710
+ if(namedTag)
711
+ {
712
+ string::size_type n = l.find_first_not_of(ws, tag.size());
713
+ if(n == string::npos)
714
+ {
715
+ return false; // Malformed line, ignore it.
716
+ }
717
+ string::size_type end = l.find_first_of(ws, n);
718
+ if(end == string::npos)
719
+ {
720
+ return false; // Malformed line, ignore it.
721
+ }
722
+ name = l.substr(n, end - n);
723
+ n = l.find_first_not_of(ws, end);
724
+ if(n != string::npos)
725
+ {
726
+ doc = l.substr(n);
727
+ }
728
+ }
729
+ else
730
+ {
731
+ name.clear();
732
+
733
+ string::size_type n = l.find_first_not_of(ws, tag.size());
734
+ if(n == string::npos)
735
+ {
736
+ return false; // Malformed line, ignore it.
737
+ }
738
+ doc = l.substr(n);
739
+ }
740
+
741
+ return true;
742
+ }
743
+
744
+ return false;
745
+ }
746
+
747
+ }
748
+
749
+ CommentPtr
750
+ Slice::Contained::parseComment(bool stripMarkup) const
751
+ {
752
+ CommentPtr comment = new Comment;
753
+
754
+ comment->_isDeprecated = false;
755
+
756
+ //
757
+ // First check metadata for a deprecated tag.
758
+ //
759
+ string deprecateMetadata;
760
+ if(findMetaData("deprecate", deprecateMetadata))
761
+ {
762
+ comment->_isDeprecated = true;
763
+ if(deprecateMetadata.find("deprecate:") == 0 && deprecateMetadata.size() > 10)
764
+ {
765
+ comment->_deprecated.push_back(IceUtilInternal::trim(deprecateMetadata.substr(10)));
766
+ }
767
+ }
768
+
769
+ if(!comment->_isDeprecated && _comment.empty())
770
+ {
771
+ return 0;
772
+ }
773
+
774
+ //
775
+ // Split up the comment into lines.
776
+ //
777
+ StringList lines = splitComment(_comment, stripMarkup);
778
+
779
+ StringList::const_iterator i;
780
+ for(i = lines.begin(); i != lines.end(); ++i)
781
+ {
782
+ const string l = *i;
783
+ if(l[0] == '@')
784
+ {
785
+ break;
786
+ }
787
+ comment->_overview.push_back(l);
788
+ }
789
+
790
+ enum State { StateMisc, StateParam, StateThrows, StateReturn, StateDeprecated };
791
+ State state = StateMisc;
792
+ string name;
793
+ const string ws = " \t";
794
+ const string paramTag = "@param";
795
+ const string throwsTag = "@throws";
796
+ const string exceptionTag = "@exception";
797
+ const string returnTag = "@return";
798
+ const string deprecatedTag = "@deprecated";
799
+ const string seeTag = "@see";
800
+ for(; i != lines.end(); ++i)
801
+ {
802
+ const string l = IceUtilInternal::trim(*i);
803
+ string line;
804
+ if(parseCommentLine(l, paramTag, true, name, line))
805
+ {
806
+ if(!line.empty())
807
+ {
808
+ state = StateParam;
809
+ StringList sl;
810
+ sl.push_back(line); // The first line of the description.
811
+ comment->_parameters[name] = sl;
812
+ }
813
+ }
814
+ else if(parseCommentLine(l, throwsTag, true, name, line))
815
+ {
816
+ if(!line.empty())
817
+ {
818
+ state = StateThrows;
819
+ StringList sl;
820
+ sl.push_back(line); // The first line of the description.
821
+ comment->_exceptions[name] = sl;
822
+ }
823
+ }
824
+ else if(parseCommentLine(l, exceptionTag, true, name, line))
825
+ {
826
+ if(!line.empty())
827
+ {
828
+ state = StateThrows;
829
+ StringList sl;
830
+ sl.push_back(line); // The first line of the description.
831
+ comment->_exceptions[name] = sl;
832
+ }
833
+ }
834
+ else if(parseCommentLine(l, seeTag, false, name, line))
835
+ {
836
+ if(!line.empty())
837
+ {
838
+ comment->_seeAlso.push_back(line);
839
+ }
840
+ }
841
+ else if(parseCommentLine(l, returnTag, false, name, line))
842
+ {
843
+ if(!line.empty())
844
+ {
845
+ state = StateReturn;
846
+ comment->_returns.push_back(line); // The first line of the description.
847
+ }
848
+ }
849
+ else if(parseCommentLine(l, deprecatedTag, false, name, line))
850
+ {
851
+ comment->_isDeprecated = true;
852
+ if(!line.empty())
853
+ {
854
+ state = StateDeprecated;
855
+ comment->_deprecated.push_back(line); // The first line of the description.
856
+ }
857
+ }
858
+ else if(!l.empty())
859
+ {
860
+ if(l[0] == '@')
861
+ {
862
+ //
863
+ // Treat all other tags as miscellaneous comments.
864
+ //
865
+ state = StateMisc;
866
+ }
867
+
868
+ switch(state)
869
+ {
870
+ case StateMisc:
871
+ {
872
+ comment->_misc.push_back(l);
873
+ break;
874
+ }
875
+ case StateParam:
876
+ {
877
+ assert(!name.empty());
878
+ StringList sl;
879
+ if(comment->_parameters.find(name) != comment->_parameters.end())
880
+ {
881
+ sl = comment->_parameters[name];
882
+ }
883
+ sl.push_back(l);
884
+ comment->_parameters[name] = sl;
885
+ break;
886
+ }
887
+ case StateThrows:
888
+ {
889
+ assert(!name.empty());
890
+ StringList sl;
891
+ if(comment->_exceptions.find(name) != comment->_exceptions.end())
892
+ {
893
+ sl = comment->_exceptions[name];
894
+ }
895
+ sl.push_back(l);
896
+ comment->_exceptions[name] = sl;
897
+ break;
898
+ }
899
+ case StateReturn:
900
+ {
901
+ comment->_returns.push_back(l);
902
+ break;
903
+ }
904
+ case StateDeprecated:
905
+ {
906
+ comment->_deprecated.push_back(l);
907
+ break;
908
+ }
909
+ }
910
+ }
911
+ }
912
+
913
+ trimLines(comment->_overview);
914
+ trimLines(comment->_deprecated);
915
+ trimLines(comment->_misc);
916
+ trimLines(comment->_returns);
917
+
918
+ return comment;
919
+ }
920
+
541
921
  int
542
922
  Slice::Contained::includeLevel() const
543
923
  {
@@ -677,7 +1057,6 @@ Slice::Container::destroy()
677
1057
  ModulePtr
678
1058
  Slice::Container::createModule(const string& name)
679
1059
  {
680
- checkIdentifier(name);
681
1060
  ContainedList matches = _unit->findContents(thisScope() + name);
682
1061
  matches.sort(); // Modules can occur many times...
683
1062
  matches.unique(); // ... but we only want one instance of each.
@@ -730,8 +1109,6 @@ Slice::Container::createModule(const string& name)
730
1109
  ClassDefPtr
731
1110
  Slice::Container::createClassDef(const string& name, int id, bool intf, const ClassList& bases, bool local)
732
1111
  {
733
- checkIdentifier(name);
734
-
735
1112
  ContainedList matches = _unit->findContents(thisScope() + name);
736
1113
  for(ContainedList::const_iterator p = matches.begin(); p != matches.end(); ++p)
737
1114
  {
@@ -812,20 +1189,15 @@ Slice::Container::createClassDef(const string& name, int id, bool intf, const Cl
812
1189
  // definition. This way the code generator can rely on always
813
1190
  // having a class declaration available for lookup.
814
1191
  //
815
- ClassDeclPtr decl = createClassDecl(name, intf, local, false);
1192
+ ClassDeclPtr decl = createClassDecl(name, intf, local);
816
1193
  def->_declaration = decl;
817
1194
 
818
1195
  return def;
819
1196
  }
820
1197
 
821
1198
  ClassDeclPtr
822
- Slice::Container::createClassDecl(const string& name, bool intf, bool local, bool checkName)
1199
+ Slice::Container::createClassDecl(const string& name, bool intf, bool local)
823
1200
  {
824
- if (checkName)
825
- {
826
- checkIdentifier(name);
827
- }
828
-
829
1201
  ClassDefPtr def;
830
1202
 
831
1203
  ContainedList matches = _unit->findContents(thisScope() + name);
@@ -915,8 +1287,6 @@ Slice::Container::createClassDecl(const string& name, bool intf, bool local, boo
915
1287
  ExceptionPtr
916
1288
  Slice::Container::createException(const string& name, const ExceptionPtr& base, bool local, NodeType nt)
917
1289
  {
918
- checkIdentifier(name);
919
-
920
1290
  ContainedList matches = _unit->findContents(thisScope() + name);
921
1291
  if(!matches.empty())
922
1292
  {
@@ -967,8 +1337,6 @@ Slice::Container::createException(const string& name, const ExceptionPtr& base,
967
1337
  StructPtr
968
1338
  Slice::Container::createStruct(const string& name, bool local, NodeType nt)
969
1339
  {
970
- checkIdentifier(name);
971
-
972
1340
  ContainedList matches = _unit->findContents(thisScope() + name);
973
1341
  if(!matches.empty())
974
1342
  {
@@ -1012,8 +1380,6 @@ SequencePtr
1012
1380
  Slice::Container::createSequence(const string& name, const TypePtr& type, const StringList& metaData, bool local,
1013
1381
  NodeType nt)
1014
1382
  {
1015
- checkIdentifier(name);
1016
-
1017
1383
  ContainedList matches = _unit->findContents(thisScope() + name);
1018
1384
  if(!matches.empty())
1019
1385
  {
@@ -1069,8 +1435,6 @@ Slice::Container::createDictionary(const string& name, const TypePtr& keyType, c
1069
1435
  const TypePtr& valueType, const StringList& valueMetaData, bool local,
1070
1436
  NodeType nt)
1071
1437
  {
1072
- checkIdentifier(name);
1073
-
1074
1438
  ContainedList matches = _unit->findContents(thisScope() + name);
1075
1439
  if(!matches.empty())
1076
1440
  {
@@ -1143,8 +1507,6 @@ Slice::Container::createDictionary(const string& name, const TypePtr& keyType, c
1143
1507
  EnumPtr
1144
1508
  Slice::Container::createEnum(const string& name, bool local, NodeType nt)
1145
1509
  {
1146
- checkIdentifier(name);
1147
-
1148
1510
  ContainedList matches = _unit->findContents(thisScope() + name);
1149
1511
  if(!matches.empty())
1150
1512
  {
@@ -1213,8 +1575,6 @@ Slice::Container::createConst(const string name, const TypePtr& constType, const
1213
1575
  const SyntaxTreeBasePtr& valueType, const string& value, const string& literal,
1214
1576
  NodeType nt)
1215
1577
  {
1216
- checkIdentifier(name);
1217
-
1218
1578
  ContainedList matches = _unit->findContents(thisScope() + name);
1219
1579
  if(!matches.empty())
1220
1580
  {
@@ -2559,74 +2919,6 @@ Slice::Container::Container(const UnitPtr& unit) :
2559
2919
  {
2560
2920
  }
2561
2921
 
2562
- void
2563
- Slice::Container::checkIdentifier(const string& name) const
2564
- {
2565
- //
2566
- // Weed out identifiers with reserved suffixes.
2567
- //
2568
- static const string suffixBlacklist[] = { "Helper", "Holder", "Prx", "Ptr" };
2569
- for(size_t i = 0; i < sizeof(suffixBlacklist) / sizeof(*suffixBlacklist); ++i)
2570
- {
2571
- if(name.find(suffixBlacklist[i], name.size() - suffixBlacklist[i].size()) != string::npos)
2572
- {
2573
- _unit->error("illegal identifier `" + name + "': `" + suffixBlacklist[i] + "' suffix is reserved");
2574
- }
2575
- }
2576
-
2577
- //
2578
- // Check for illegal underscores.
2579
- //
2580
- if(name.find('_') == 0)
2581
- {
2582
- _unit->error("illegal leading underscore in identifier `" + name + "'");
2583
- }
2584
- else if(name.rfind('_') == name.size() - 1)
2585
- {
2586
- _unit->error("illegal trailing underscore in identifier `" + name + "'");
2587
- }
2588
- else if(name.find("__") != string::npos)
2589
- {
2590
- _unit->error("illegal double underscore in identifier `" + name + "'");
2591
- }
2592
- else if(_unit->currentIncludeLevel() == 0 && !_unit->allowUnderscore() && name.find('_') != string::npos)
2593
- {
2594
- //
2595
- // For rules controlled by a translator option, we don't complain about included files.
2596
- //
2597
-
2598
- DefinitionContextPtr dc = _unit->currentDefinitionContext();
2599
- assert(dc);
2600
- if(dc->findMetaData("underscore") != "underscore") // no "underscore" global metadata
2601
- {
2602
- _unit->error("illegal underscore in identifier `" + name + "'");
2603
- }
2604
- }
2605
-
2606
- //
2607
- // For rules controlled by a translator option, we don't complain about included files.
2608
- //
2609
- if(_unit->currentIncludeLevel() == 0 && !_unit->allowIcePrefix())
2610
- {
2611
- DefinitionContextPtr dc = _unit->currentDefinitionContext();
2612
- assert(dc);
2613
- if(dc->findMetaData("ice-prefix") != "ice-prefix") // no "ice-prefix" global metadata
2614
- {
2615
- if(name.size() >= 3)
2616
- {
2617
- string prefix3;
2618
- prefix3 += ::tolower(static_cast<unsigned char>(name[0]));
2619
- prefix3 += ::tolower(static_cast<unsigned char>(name[1]));
2620
- prefix3 += ::tolower(static_cast<unsigned char>(name[2]));
2621
- if(prefix3 == "ice")
2622
- {
2623
- _unit->error("illegal identifier `" + name + "': `" + name.substr(0, 3) + "' prefix is reserved");
2624
- }
2625
- }
2626
- }
2627
- }
2628
- }
2629
-
2630
2922
  bool
2631
2923
  Slice::Container::checkInterfaceAndLocal(const string& name, bool defined,
2632
2924
  bool intf, bool intfOther,
@@ -3014,8 +3306,6 @@ Slice::Container::validateConstant(const string& name, const TypePtr& type, Synt
3014
3306
  EnumeratorPtr
3015
3307
  Slice::Container::validateEnumerator(const string& name)
3016
3308
  {
3017
- checkIdentifier(name);
3018
-
3019
3309
  ContainedList matches = _unit->findContents(thisScope() + name);
3020
3310
  if(!matches.empty())
3021
3311
  {
@@ -3421,8 +3711,6 @@ Slice::ClassDef::createOperation(const string& name,
3421
3711
  int tag,
3422
3712
  Operation::Mode mode)
3423
3713
  {
3424
- checkIdentifier(name);
3425
-
3426
3714
  ContainedList matches = _unit->findContents(thisScope() + name);
3427
3715
  if(!matches.empty())
3428
3716
  {
@@ -3533,8 +3821,6 @@ Slice::ClassDef::createDataMember(const string& name, const TypePtr& type, bool
3533
3821
  const SyntaxTreeBasePtr& defaultValueType, const string& defaultValue,
3534
3822
  const string& defaultLiteral)
3535
3823
  {
3536
- checkIdentifier(name);
3537
-
3538
3824
  assert(!isInterface());
3539
3825
  ContainedList matches = _unit->findContents(thisScope() + name);
3540
3826
  if(!matches.empty())
@@ -4082,8 +4368,6 @@ Slice::Exception::createDataMember(const string& name, const TypePtr& type, bool
4082
4368
  const SyntaxTreeBasePtr& defaultValueType, const string& defaultValue,
4083
4369
  const string& defaultLiteral)
4084
4370
  {
4085
- checkIdentifier(name);
4086
-
4087
4371
  ContainedList matches = _unit->findContents(thisScope() + name);
4088
4372
  if(!matches.empty())
4089
4373
  {
@@ -5289,8 +5573,6 @@ Slice::Operation::hasMarshaledResult() const
5289
5573
  ParamDeclPtr
5290
5574
  Slice::Operation::createParamDecl(const string& name, const TypePtr& type, bool isOutParam, bool optional, int tag)
5291
5575
  {
5292
- checkIdentifier(name);
5293
-
5294
5576
  ContainedList matches = _unit->findContents(thisScope() + name);
5295
5577
  if(!matches.empty())
5296
5578
  {