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
@@ -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.
@@ -20,24 +20,40 @@ namespace Ice
20
20
 
21
21
  class LocalException;
22
22
 
23
+ /**
24
+ * Helper template for local exceptions.
25
+ * \headerfile Ice/Ice.h
26
+ */
23
27
  template<typename T, typename B> class LocalExceptionHelper : public IceUtil::ExceptionHelper<T, B>
24
28
  {
25
29
  public:
26
30
 
27
31
  using IceUtil::ExceptionHelper<T, B>::ExceptionHelper;
28
32
 
33
+ /**
34
+ * Obtains the Slice type ID of this exception.
35
+ * @return The fully-scoped type ID.
36
+ */
29
37
  virtual std::string ice_id() const override
30
38
  {
31
39
  return T::ice_staticId();
32
40
  }
33
41
  };
34
42
 
43
+ /**
44
+ * Helper template for user exceptions.
45
+ * \headerfile Ice/Ice.h
46
+ */
35
47
  template<typename T, typename B> class UserExceptionHelper : public IceUtil::ExceptionHelper<T, B>
36
48
  {
37
49
  public:
38
50
 
39
51
  using IceUtil::ExceptionHelper<T, B>::ExceptionHelper;
40
52
 
53
+ /**
54
+ * Obtains the Slice type ID of this exception.
55
+ * @return The fully-scoped type ID.
56
+ */
41
57
  virtual std::string ice_id() const override
42
58
  {
43
59
  return T::ice_staticId();
@@ -45,6 +61,7 @@ public:
45
61
 
46
62
  protected:
47
63
 
64
+ /// \cond STREAM
48
65
  virtual void _writeImpl(Ice::OutputStream* os) const override
49
66
  {
50
67
  os->startSlice(T::ice_staticId(), -1, std::is_same<B, Ice::LocalException>::value ? true : false);
@@ -60,6 +77,7 @@ protected:
60
77
  is->endSlice();
61
78
  B::_readImpl(is);
62
79
  }
80
+ /// \endcond
63
81
  };
64
82
 
65
83
  }
@@ -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.
@@ -17,11 +17,21 @@
17
17
  namespace Ice
18
18
  {
19
19
 
20
+ /**
21
+ * The base class for a compact ID resolver. Subclasses must implement resolve.
22
+ * The resolver can be installed via InitializationData.
23
+ * \headerfile Ice/Ice.h
24
+ */
20
25
  class ICE_API CompactIdResolver : public IceUtil::Shared
21
26
  {
22
27
  public:
23
28
 
24
- virtual ::std::string resolve(Ice::Int) const = 0;
29
+ /**
30
+ * Called by the Ice run time when a compact ID must be translated into a type ID.
31
+ * @param id The compact ID.
32
+ * @return The fully-scoped Slice type ID, or an empty string if the compact ID is unknown.
33
+ */
34
+ virtual ::std::string resolve(Ice::Int id) const = 0;
25
35
  };
26
36
  typedef IceUtil::Handle<CompactIdResolver> CompactIdResolverPtr;
27
37
 
@@ -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.
@@ -15,27 +15,26 @@
15
15
  namespace Ice
16
16
  {
17
17
 
18
- //
19
- // This enumeration describes the possible formats for classes and exceptions.
20
- //
21
-
18
+ /**
19
+ * Describes the possible formats for classes and exceptions.
20
+ */
22
21
  #ifdef ICE_CPP11_MAPPING
23
22
  enum class FormatType : unsigned char
24
23
  #else
25
24
  enum FormatType
26
25
  #endif
27
26
  {
28
- //
29
- // Indicates that no preference was specified.
30
- //
27
+ /**
28
+ * Indicates that no preference was specified.
29
+ */
31
30
  DefaultFormat,
32
- //
33
- // A minimal format that eliminates the possibility for slicing unrecognized types.
34
- //
31
+ /**
32
+ * A minimal format that eliminates the possibility for slicing unrecognized types.
33
+ */
35
34
  CompactFormat,
36
- //
37
- // Allow slicing and preserve slices for unknown types.
38
- //
35
+ /**
36
+ * Allow slicing and preserve slices for unknown types.
37
+ */
39
38
  SlicedFormat
40
39
  };
41
40
 
@@ -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.
@@ -10,6 +10,8 @@
10
10
  #ifndef ICE_FUNCTIONAL_H
11
11
  #define ICE_FUNCTIONAL_H
12
12
 
13
+ # if !defined(ICE_CPP11_MAPPING) || defined(ICE_BUILDING_SRC)
14
+
13
15
  #include <IceUtil/Functional.h>
14
16
  #include <Ice/Handle.h>
15
17
 
@@ -21,6 +23,7 @@
21
23
  namespace Ice
22
24
  {
23
25
 
26
+ /// \cond INTERNAL
24
27
  template<class R, class T>
25
28
  inline ::IceUtilInternal::MemFun<R, T, ICE_INTERNAL_HANDLE<T> >
26
29
  memFun(R (T::*p)(void))
@@ -132,7 +135,9 @@ secondConstVoidMemFun1(void (T::*p)(A) const)
132
135
  {
133
136
  return ::IceUtilInternal::SecondConstVoidMemFun1<K, T, ICE_INTERNAL_HANDLE<T>, A>(p);
134
137
  }
138
+ /// \endcond
135
139
 
136
140
  }
137
141
 
142
+ # endif
138
143
  #endif
@@ -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.
@@ -36,23 +36,50 @@
36
36
  namespace Ice
37
37
  {
38
38
 
39
+ /**
40
+ * Indicates that Iconv does not support the code.
41
+ * \headerfile Ice/Ice.h
42
+ */
39
43
  class ICE_API IconvInitializationException : public IceUtil::ExceptionHelper<IconvInitializationException>
40
44
  {
41
45
  public:
42
46
 
43
- IconvInitializationException(const char*, int, const std::string&);
47
+ /**
48
+ * Constructs the exception with a reason. The file and line number are required.
49
+ * @param file The file name in which the exception was raised, typically __FILE__.
50
+ * @param line The line number at which the exception was raised, typically __LINE__.
51
+ * @param reason More detail about the failure.
52
+ */
53
+ IconvInitializationException(const char* file, int line, const std::string& reason);
44
54
 
45
55
  #ifndef ICE_CPP11_COMPILER
46
56
  virtual ~IconvInitializationException() throw();
47
57
  #endif
48
58
 
59
+ /**
60
+ * Obtains the Slice type ID of this exception.
61
+ * @return The fully-scoped type ID.
62
+ */
49
63
  virtual std::string ice_id() const;
50
- virtual void ice_print(std::ostream&) const;
64
+
65
+ /**
66
+ * Prints a description of this exception to the given stream.
67
+ * @param str The output stream.
68
+ */
69
+ virtual void ice_print(std::ostream& str) const;
51
70
 
52
71
  #ifndef ICE_CPP11_MAPPING
72
+ /**
73
+ * Polymporphically clones this exception.
74
+ * @return A shallow copy of this exception.
75
+ */
53
76
  virtual IconvInitializationException* ice_clone() const;
54
77
  #endif
55
78
 
79
+ /**
80
+ * Obtains the reason for the failure.
81
+ * @return The reason.
82
+ */
56
83
  std::string reason() const;
57
84
 
58
85
  private:
@@ -329,6 +356,13 @@ IconvStringConverter<charT>::fromUTF8(const Ice::Byte* sourceStart, const Ice::B
329
356
 
330
357
  namespace Ice
331
358
  {
359
+
360
+ /**
361
+ * Creates a string converter for the given code.
362
+ * @param internalCodeWithDefault The desired code. If empty or not provided, a default code is used.
363
+ * @return The converter object.
364
+ * @throws IconvInitializationException If the code is not supported.
365
+ */
332
366
  template<typename charT>
333
367
  ICE_HANDLE<IceUtil::BasicStringConverter<charT> >
334
368
  createIconvStringConverter(const std::string& internalCodeWithDefault = "")
@@ -342,6 +376,7 @@ createIconvStringConverter(const std::string& internalCodeWithDefault = "")
342
376
 
343
377
  return ICE_MAKE_SHARED(IceInternal::IconvStringConverter<charT>, internalCode);
344
378
  }
379
+
345
380
  }
346
381
 
347
382
  #endif
@@ -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.
@@ -29,12 +29,24 @@
29
29
  namespace Ice
30
30
  {
31
31
 
32
+ /**
33
+ * Base class for marshaled result structures, which are generated for operations having the
34
+ * marshaled-result metadata tag.
35
+ * \headerfile Ice/Ice.h
36
+ */
32
37
  class ICE_API MarshaledResult
33
38
  {
34
39
  public:
35
40
 
36
- MarshaledResult(const Current&);
41
+ /**
42
+ * The constructor requires the Current object that was passed to the servant.
43
+ */
44
+ MarshaledResult(const Current& current);
37
45
 
46
+ /**
47
+ * Obtains the output stream that is used to marshal the results.
48
+ * @return The output stream.
49
+ */
38
50
  std::shared_ptr<OutputStream> getOutputStream() const
39
51
  {
40
52
  return ostr;
@@ -42,6 +54,7 @@ public:
42
54
 
43
55
  protected:
44
56
 
57
+ /** The output stream used to marshal the results. */
45
58
  std::shared_ptr<OutputStream> ostr;
46
59
  };
47
60
 
@@ -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.
@@ -17,13 +17,25 @@
17
17
  namespace Ice
18
18
  {
19
19
 
20
+ /**
21
+ * Base class for generated AMD callback classes.
22
+ * \headerfile Ice/Ice.h
23
+ */
20
24
  class ICE_API AMDCallback : public Ice::LocalObject
21
25
  {
22
26
  public:
23
27
 
24
28
  virtual ~AMDCallback();
25
29
 
26
- virtual void ice_exception(const ::std::exception&) = 0;
30
+ /**
31
+ * Completes the asynchronous request with the given exception.
32
+ * @param ex The exception that completed the request.
33
+ */
34
+ virtual void ice_exception(const ::std::exception& ex) = 0;
35
+
36
+ /**
37
+ * Completes the asynchronous request with an UnknownException.
38
+ */
27
39
  virtual void ice_exception() = 0;
28
40
  };
29
41
 
@@ -112,18 +124,38 @@ private:
112
124
  namespace Ice
113
125
  {
114
126
 
127
+ /**
128
+ * Base class for the AMD callback for BlobjectAsync::ice_invoke_async.
129
+ * \headerfile Ice/Ice.h
130
+ */
115
131
  class ICE_API AMD_Object_ice_invoke : public virtual Ice::AMDCallback
116
132
  {
117
133
  public:
118
134
 
119
135
  virtual ~AMD_Object_ice_invoke();
120
136
 
121
- virtual void ice_response(bool, const std::vector<Ice::Byte>&) = 0;
122
- virtual void ice_response(bool, const std::pair<const Ice::Byte*, const Ice::Byte*>&) = 0;
137
+ /**
138
+ * Completes the request.
139
+ * @param ok True if the request completed successfully, in which case bytes contains an encapsulation
140
+ * of the marshaled results. False if the request completed with a user exception, in which case bytes
141
+ * contains an encapsulation of the marshaled user exception.
142
+ * @param bytes An encapsulation of the results or user exception.
143
+ */
144
+ virtual void ice_response(bool ok, const std::vector<Ice::Byte>& bytes) = 0;
145
+
146
+ /**
147
+ * Completes the request.
148
+ * @param ok True if the request completed successfully, in which case bytes contains an encapsulation
149
+ * of the marshaled results. False if the request completed with a user exception, in which case bytes
150
+ * contains an encapsulation of the marshaled user exception.
151
+ * @param bytes An encapsulation of the results or user exception.
152
+ */
153
+ virtual void ice_response(bool ok, const std::pair<const Ice::Byte*, const Ice::Byte*>& bytes) = 0;
123
154
  };
124
155
 
125
156
  }
126
157
 
158
+ /// \cond INTERNAL
127
159
  namespace IceAsync
128
160
  {
129
161
 
@@ -143,6 +175,7 @@ public:
143
175
  }
144
176
 
145
177
  }
178
+ /// \endcond
146
179
  #endif
147
180
 
148
181
  #endif
@@ -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.
@@ -32,112 +32,431 @@
32
32
  namespace Ice
33
33
  {
34
34
 
35
- ICE_API StringSeq argsToStringSeq(int, const char* const[]);
35
+ /**
36
+ * Converts an argument vector into a string sequence.
37
+ * @param argc The number of arguments in argv.
38
+ * @param argv The arguments.
39
+ * @return A string sequence containing the arguments.
40
+ */
41
+ ICE_API StringSeq argsToStringSeq(int argc, const char* const argv[]);
36
42
 
37
43
  #ifdef _WIN32
38
- ICE_API StringSeq argsToStringSeq(int, const wchar_t* const[]);
44
+ /**
45
+ * Converts an argument vector into a string sequence.
46
+ * @param argc The number of arguments in argv.
47
+ * @param argv The arguments.
48
+ * @return A string sequence containing the arguments.
49
+ */
50
+ ICE_API StringSeq argsToStringSeq(int argc, const wchar_t* const argv[]);
39
51
  #endif
40
52
 
41
- //
42
- // This function assumes that the string sequence only contains
43
- // elements of the argument vector. The function shifts the
44
- // the argument vector elements so that the vector matches the
45
- // contents of the sequence.
46
- //
47
- ICE_API void stringSeqToArgs(const StringSeq&, int&, const char*[]);
53
+ /**
54
+ * Updates the argument vector to match the contents of the string sequence.
55
+ * This function assumes that the string sequence only contains
56
+ * elements of the argument vector. The function shifts the
57
+ * the argument vector elements so that the vector matches the
58
+ * contents of the sequence.
59
+ * @param seq The string sequence returned from a call to argsToStringSeq.
60
+ * @param argc Updated to reflect the size of the sequence.
61
+ * @param argv Elements are shifted to match the sequence.
62
+ */
63
+ ICE_API void stringSeqToArgs(const StringSeq& seq, int& argc, const char* argv[]);
64
+
65
+ /**
66
+ * Updates the argument vector to match the contents of the string sequence.
67
+ * This function assumes that the string sequence only contains
68
+ * elements of the argument vector. The function shifts the
69
+ * the argument vector elements so that the vector matches the
70
+ * contents of the sequence.
71
+ * @param seq The string sequence returned from a call to argsToStringSeq.
72
+ * @param argc Updated to reflect the size of the sequence.
73
+ * @param argv Elements are shifted to match the sequence.
74
+ */
48
75
  inline void stringSeqToArgs(const StringSeq& seq, int& argc, char* argv[])
49
76
  {
50
77
  return stringSeqToArgs(seq, argc, const_cast<const char**>(argv));
51
78
  }
52
79
 
53
80
  #ifdef _WIN32
54
- ICE_API void stringSeqToArgs(const StringSeq&, int&, const wchar_t*[]);
81
+ /**
82
+ * Updates the argument vector to match the contents of the string sequence.
83
+ * This function assumes that the string sequence only contains
84
+ * elements of the argument vector. The function shifts the
85
+ * the argument vector elements so that the vector matches the
86
+ * contents of the sequence.
87
+ * @param seq The string sequence returned from a call to argsToStringSeq.
88
+ */
89
+ ICE_API void stringSeqToArgs(const StringSeq& seq, int& argc, const wchar_t* argv[]);
90
+
91
+ /**
92
+ * Updates the argument vector to match the contents of the string sequence.
93
+ * This function assumes that the string sequence only contains
94
+ * elements of the argument vector. The function shifts the
95
+ * the argument vector elements so that the vector matches the
96
+ * contents of the sequence.
97
+ * @param seq The string sequence returned from a call to argsToStringSeq.
98
+ */
55
99
  inline void stringSeqToArgs(const StringSeq& seq, int& argc, wchar_t* argv[])
56
100
  {
57
101
  return stringSeqToArgs(seq, argc, const_cast<const wchar_t**>(argv));
58
102
  }
59
103
  #endif
60
104
 
105
+ /**
106
+ * Creates a new empty property set.
107
+ *
108
+ * @return A new empty property set.
109
+ */
61
110
  ICE_API PropertiesPtr createProperties();
62
- ICE_API PropertiesPtr createProperties(StringSeq&, const PropertiesPtr& = 0);
63
- ICE_API PropertiesPtr createProperties(int&, const char*[], const PropertiesPtr& = 0);
64
- inline PropertiesPtr createProperties(int& argc, char* argv[], const PropertiesPtr& props = 0)
111
+
112
+ /**
113
+ * Creates a property set initialized from command-line arguments
114
+ * and a default property set.
115
+ *
116
+ * @param seq Command-line arguments, possibly containing
117
+ * options to set properties. If the arguments include
118
+ * a <code>--Ice.Config</code> option, the corresponding configuration
119
+ * files are parsed. If the same property is set in a configuration
120
+ * file and in the arguments, the arguments take precedence.
121
+ * Recognized options are removed from this container upon return.
122
+ *
123
+ * @param defaults Default values for the property set. Settings in
124
+ * configuration files and the arguments override these defaults.
125
+ *
126
+ * @return A new property set initialized with the property settings
127
+ * that were removed from the argument vector.
128
+ */
129
+ ICE_API PropertiesPtr createProperties(StringSeq& seq, const PropertiesPtr& defaults = 0);
130
+
131
+ /**
132
+ * Creates a property set initialized from command-line arguments
133
+ * and a default property set.
134
+ *
135
+ * @param argc The number of arguments in argv. Upon return, this argument
136
+ * is updated to reflect the arguments still remaining in argv.
137
+ * @param argv Command-line arguments, possibly containing
138
+ * options to set properties. If the arguments include
139
+ * a <code>--Ice.Config</code> option, the corresponding configuration
140
+ * files are parsed. If the same property is set in a configuration
141
+ * file and in the arguments, the arguments take precedence.
142
+ * Recognized options are removed from this vector upon return.
143
+ *
144
+ * @param defaults Default values for the property set. Settings in
145
+ * configuration files and the arguments override these defaults.
146
+ *
147
+ * @return A new property set initialized with the property settings
148
+ * that were removed from the argument vector.
149
+ */
150
+ ICE_API PropertiesPtr createProperties(int& argc, const char* argv[], const PropertiesPtr& defaults = 0);
151
+
152
+ /**
153
+ * Creates a property set initialized from command-line arguments
154
+ * and a default property set.
155
+ *
156
+ * @param argc The number of arguments in argv. Upon return, this argument
157
+ * is updated to reflect the arguments still remaining in argv.
158
+ * @param argv Command-line arguments, possibly containing
159
+ * options to set properties. If the arguments include
160
+ * a <code>--Ice.Config</code> option, the corresponding configuration
161
+ * files are parsed. If the same property is set in a configuration
162
+ * file and in the arguments, the arguments take precedence.
163
+ * Recognized options are removed from this vector upon return.
164
+ *
165
+ * @param defaults Default values for the property set. Settings in
166
+ * configuration files and the arguments override these defaults.
167
+ *
168
+ * @return A new property set initialized with the property settings
169
+ * that were removed from the argument vector.
170
+ */
171
+ inline PropertiesPtr createProperties(int& argc, char* argv[], const PropertiesPtr& defaults = 0)
65
172
  {
66
- return createProperties(argc, const_cast<const char**>(argv), props);
173
+ return createProperties(argc, const_cast<const char**>(argv), defaults);
67
174
  }
68
175
 
69
176
  #ifdef _WIN32
70
- ICE_API PropertiesPtr createProperties(int&, const wchar_t*[], const PropertiesPtr& = 0);
71
- inline PropertiesPtr createProperties(int& argc, wchar_t* argv[], const PropertiesPtr& props = 0)
177
+ /**
178
+ * Creates a property set initialized from command-line arguments
179
+ * and a default property set.
180
+ *
181
+ * @param argc The number of arguments in argv. Upon return, this argument
182
+ * is updated to reflect the arguments still remaining in argv.
183
+ * @param argv Command-line arguments, possibly containing
184
+ * options to set properties. If the arguments include
185
+ * a <code>--Ice.Config</code> option, the corresponding configuration
186
+ * files are parsed. If the same property is set in a configuration
187
+ * file and in the arguments, the arguments take precedence.
188
+ * Recognized options are removed from this vector upon return.
189
+ *
190
+ * @param defaults Default values for the property set. Settings in
191
+ * configuration files and the arguments override these defaults.
192
+ *
193
+ * @return A new property set initialized with the property settings
194
+ * that were removed from the argument vector.
195
+ */
196
+ ICE_API PropertiesPtr createProperties(int& argc, const wchar_t* argv[], const PropertiesPtr& defaults = 0);
197
+
198
+ /**
199
+ * Creates a property set initialized from command-line arguments
200
+ * and a default property set.
201
+ *
202
+ * @param argc The number of arguments in argv. Upon return, this argument
203
+ * is updated to reflect the arguments still remaining in argv.
204
+ * @param argv Command-line arguments, possibly containing
205
+ * options to set properties. If the arguments include
206
+ * a <code>--Ice.Config</code> option, the corresponding configuration
207
+ * files are parsed. If the same property is set in a configuration
208
+ * file and in the arguments, the arguments take precedence.
209
+ * Recognized options are removed from this vector upon return.
210
+ *
211
+ * @param defaults Default values for the property set. Settings in
212
+ * configuration files and the arguments override these defaults.
213
+ *
214
+ * @return A new property set initialized with the property settings
215
+ * that were removed from the argument vector.
216
+ */
217
+ inline PropertiesPtr createProperties(int& argc, wchar_t* argv[], const PropertiesPtr& defaults = 0)
72
218
  {
73
- return createProperties(argc, const_cast<const wchar_t**>(argv), props);
219
+ return createProperties(argc, const_cast<const wchar_t**>(argv), defaults);
74
220
  }
75
221
  #endif
76
222
 
77
- //
78
- // This class is used to notify user of when Ice threads are started
79
- // and stopped.
80
- //
223
+ /**
224
+ * Base class for a thread notification hook. An application can subclass this class,
225
+ * implement start and stop, and install an instance in InitializationData in order
226
+ * to receive notifications when Ice threads are started and stopped.
227
+ * \headerfile Ice/Ice.h
228
+ */
81
229
  class ICE_API ThreadNotification : public IceUtil::Shared
82
230
  {
83
231
  public:
84
232
 
233
+ /**
234
+ * Called from the new Ice thread at startup.
235
+ */
85
236
  virtual void start() = 0;
237
+
238
+ /**
239
+ * Called from an Ice thread that is about to stop.
240
+ */
86
241
  virtual void stop() = 0;
87
242
  };
88
243
 
89
244
  typedef IceUtil::Handle<ThreadNotification> ThreadNotificationPtr;
90
245
 
91
- //
92
- // A special plug-in that installs thread hook during a communicator's initialization.
93
- // Both initialize and destroy are no-op. See Ice::InitializationData.
94
- //
246
+ /**
247
+ * A special plug-in that installs a thread hook during a communicator's initialization.
248
+ * Both initialize and destroy are no-op. See InitializationData.
249
+ * \headerfile Ice/Ice.h
250
+ */
95
251
  class ICE_API ThreadHookPlugin : public Ice::Plugin
96
252
  {
97
253
  public:
98
254
 
99
255
  #ifdef ICE_CPP11_MAPPING
100
- ThreadHookPlugin(const CommunicatorPtr& communicator, std::function<void()>, std::function<void()>);
256
+ /**
257
+ * Installs the thread hooks.
258
+ * @param communicator The communicator in which to install the thread hooks.
259
+ * @param start The start callback.
260
+ * @param stop The stop callback.
261
+ */
262
+ ThreadHookPlugin(const CommunicatorPtr& communicator, std::function<void()> start, std::function<void()> stop);
101
263
  #else
102
- ThreadHookPlugin(const CommunicatorPtr& communicator, const ThreadNotificationPtr&);
264
+ /**
265
+ * Installs the thread hooks.
266
+ * @param communicator The communicator in which to install the thread hooks.
267
+ * @param hook The thread notification callback object.
268
+ */
269
+ ThreadHookPlugin(const CommunicatorPtr& communicator, const ThreadNotificationPtr& hook);
103
270
  #endif
271
+
272
+ /** Not used. */
104
273
  virtual void initialize();
105
274
 
275
+ /** Not used. */
106
276
  virtual void destroy();
107
277
  };
108
278
 
109
- //
110
- // Communicator initialization info
111
- //
279
+ /**
280
+ * Encapsulates data to initialize a communicator.
281
+ * \headerfile Ice/Ice.h
282
+ */
112
283
  struct InitializationData
113
284
  {
285
+ /**
286
+ * The properties for the communicator.
287
+ */
114
288
  PropertiesPtr properties;
289
+
290
+ /**
291
+ * The logger for the communicator.
292
+ */
115
293
  LoggerPtr logger;
294
+
295
+ /**
296
+ * The communicator observer used by the Ice run-time.
297
+ */
116
298
  Instrumentation::CommunicatorObserverPtr observer;
299
+
117
300
  #ifdef ICE_CPP11_MAPPING
301
+ /**
302
+ * Called whenever the communicator starts a new thread.
303
+ */
118
304
  std::function<void()> threadStart;
305
+
306
+ /**
307
+ * Called whenever a thread created by the communicator is about to be destroyed.
308
+ */
119
309
  std::function<void()> threadStop;
120
- std::function<void(std::function<void()>, const std::shared_ptr<Ice::Connection>&)> dispatcher;
121
- std::function<std::string(int)> compactIdResolver;
122
- std::function<void(const Ice::BatchRequest&, int, int)> batchRequestInterceptor;
310
+
311
+ /**
312
+ * You can control which thread receives operation invocations and AMI
313
+ * callbacks by supplying a dispatcher.
314
+ *
315
+ * For example, you can use this dispatching facility to ensure that
316
+ * all invocations and callbacks are dispatched in a GUI event loop
317
+ * thread so that it is safe to invoke directly on GUI objects.
318
+ *
319
+ * The dispatcher is responsible for running (dispatching) the
320
+ * invocation or AMI callback on its favorite thread.
321
+ * @param call Represents the invocation. The dispatcher must eventually invoke this function.
322
+ * @param con The connection associated with this dispatch, or nil if no connection is
323
+ * associated with it.
324
+ */
325
+ std::function<void(std::function<void()> call, const std::shared_ptr<Ice::Connection>& con)> dispatcher;
326
+
327
+ /**
328
+ * Applications that make use of compact type IDs to conserve space
329
+ * when marshaling class instances, and also use the streaming API to
330
+ * extract such classes, can intercept the translation between compact
331
+ * type IDs and their corresponding string type IDs by installing a
332
+ * compact ID resolver.
333
+ * @param id The compact ID.
334
+ * @return The fully-scoped type ID such as "::Module::Class", or an empty string if
335
+ * the compact ID is unknown.
336
+ */
337
+ std::function<std::string(int id)> compactIdResolver;
338
+
339
+ /**
340
+ * The batch request interceptor, which is called by the Ice run time to enqueue a batch request.
341
+ * @param req An object representing the batch request.
342
+ * @param count The number of requests currently in the queue.
343
+ * @param size The number of bytes consumed by the requests currently in the queue.
344
+ */
345
+ std::function<void(const Ice::BatchRequest& req, int count, int size)> batchRequestInterceptor;
123
346
  #else
347
+ /**
348
+ * The thread hook for the communicator.
349
+ */
124
350
  ThreadNotificationPtr threadHook;
351
+
352
+ /**
353
+ * You can control which thread receives operation invocations and AMI
354
+ * callbacks by supplying a dispatcher.
355
+ *
356
+ * For example, you can use this dispatching facility to ensure that
357
+ * all invocations and callbacks are dispatched in a GUI event loop
358
+ * thread so that it is safe to invoke directly on GUI objects.
359
+ *
360
+ * The dispatcher is responsible for running (dispatching) the
361
+ * invocation or AMI callback on its favorite thread. It must eventually
362
+ * execute the provided call.
363
+ */
125
364
  DispatcherPtr dispatcher;
365
+
366
+ /**
367
+ * Applications that make use of compact type IDs to conserve space
368
+ * when marshaling class instances, and also use the streaming API to
369
+ * extract such classes, can intercept the translation between compact
370
+ * type IDs and their corresponding string type IDs by installing a
371
+ * compact ID resolver.
372
+ */
126
373
  CompactIdResolverPtr compactIdResolver;
374
+
375
+ /**
376
+ * The batch request interceptor.
377
+ */
127
378
  BatchRequestInterceptorPtr batchRequestInterceptor;
128
379
  #endif
380
+
381
+ /**
382
+ * The value factory manager.
383
+ */
129
384
  ValueFactoryManagerPtr valueFactoryManager;
130
385
  };
131
386
 
132
- ICE_API CommunicatorPtr initialize(int&, const char*[], const InitializationData& = InitializationData(),
133
- int = ICE_INT_VERSION);
387
+ /**
388
+ * Initializes a new communicator.
389
+ * @param argc The number of arguments in argv. Upon return, this argument
390
+ * is updated to reflect the arguments still remaining in argv.
391
+ * @param argv Command-line arguments, possibly containing
392
+ * options to set properties. If the arguments include
393
+ * a <code>--Ice.Config</code> option, the corresponding configuration
394
+ * files are parsed. If the same property is set in a configuration
395
+ * file and in the arguments, the arguments take precedence.
396
+ * Recognized options are removed from this vector upon return.
397
+ * @param initData Configuration data for the new Communicator.
398
+ * @param version Indicates the Ice version with which the application is compatible. If not
399
+ * specified, the version of the Ice installation is used.
400
+ * @return The new communicator.
401
+ */
402
+ ICE_API CommunicatorPtr initialize(int& argc, const char* argv[],
403
+ const InitializationData& initData = InitializationData(),
404
+ int version = ICE_INT_VERSION);
405
+
406
+ /**
407
+ * Initializes a new communicator.
408
+ * @param argc The number of arguments in argv. Upon return, this argument
409
+ * is updated to reflect the arguments still remaining in argv.
410
+ * @param argv Command-line arguments, possibly containing
411
+ * options to set properties. If the arguments include
412
+ * a <code>--Ice.Config</code> option, the corresponding configuration
413
+ * files are parsed. If the same property is set in a configuration
414
+ * file and in the arguments, the arguments take precedence.
415
+ * Recognized options are removed from this vector upon return.
416
+ * @param initData Configuration data for the new Communicator.
417
+ * @param version Indicates the Ice version with which the application is compatible. If not
418
+ * specified, the version of the Ice installation is used.
419
+ * @return The new communicator.
420
+ */
134
421
  inline CommunicatorPtr initialize(int& argc, char* argv[], const InitializationData& initData = InitializationData(),
135
422
  int version = ICE_INT_VERSION)
136
423
  {
137
424
  return initialize(argc, const_cast<const char**>(argv), initData, version);
138
425
  }
139
426
 
140
- ICE_API CommunicatorPtr initialize(int&, const char*[], ICE_CONFIG_FILE_STRING, int = ICE_INT_VERSION);
427
+ /**
428
+ * Initializes a new communicator.
429
+ * @param argc The number of arguments in argv. Upon return, this argument
430
+ * is updated to reflect the arguments still remaining in argv.
431
+ * @param argv Command-line arguments, possibly containing
432
+ * options to set properties. If the arguments include
433
+ * a <code>--Ice.Config</code> option, the corresponding configuration
434
+ * files are parsed. If the same property is set in a configuration
435
+ * file and in the arguments, the arguments take precedence.
436
+ * Recognized options are removed from this vector upon return.
437
+ * @param configFile The name of an Ice configuration file.
438
+ * @param version Indicates the Ice version with which the application is compatible. If not
439
+ * specified, the version of the Ice installation is used.
440
+ * @return The new communicator.
441
+ */
442
+ ICE_API CommunicatorPtr initialize(int& argc, const char* argv[], ICE_CONFIG_FILE_STRING configFile,
443
+ int version = ICE_INT_VERSION);
444
+
445
+ /**
446
+ * Initializes a new communicator.
447
+ * @param argc The number of arguments in argv. Upon return, this argument
448
+ * is updated to reflect the arguments still remaining in argv.
449
+ * @param argv Command-line arguments, possibly containing
450
+ * options to set properties. If the arguments include
451
+ * a <code>--Ice.Config</code> option, the corresponding configuration
452
+ * files are parsed. If the same property is set in a configuration
453
+ * file and in the arguments, the arguments take precedence.
454
+ * Recognized options are removed from this vector upon return.
455
+ * @param configFile The name of an Ice configuration file.
456
+ * @param version Indicates the Ice version with which the application is compatible. If not
457
+ * specified, the version of the Ice installation is used.
458
+ * @return The new communicator.
459
+ */
141
460
  inline CommunicatorPtr initialize(int& argc, char* argv[], ICE_CONFIG_FILE_STRING configFile,
142
461
  int version = ICE_INT_VERSION)
143
462
  {
@@ -145,15 +464,79 @@ inline CommunicatorPtr initialize(int& argc, char* argv[], ICE_CONFIG_FILE_STRIN
145
464
  }
146
465
 
147
466
  #ifdef _WIN32
148
- ICE_API CommunicatorPtr initialize(int&, const wchar_t*[], const InitializationData& = InitializationData(),
149
- int = ICE_INT_VERSION);
467
+ /**
468
+ * Initializes a new communicator.
469
+ * @param argc The number of arguments in argv. Upon return, this argument
470
+ * is updated to reflect the arguments still remaining in argv.
471
+ * @param argv Command-line arguments, possibly containing
472
+ * options to set properties. If the arguments include
473
+ * a <code>--Ice.Config</code> option, the corresponding configuration
474
+ * files are parsed. If the same property is set in a configuration
475
+ * file and in the arguments, the arguments take precedence.
476
+ * Recognized options are removed from this vector upon return.
477
+ * @param initData Configuration data for the new Communicator.
478
+ * @param version Indicates the Ice version with which the application is compatible. If not
479
+ * specified, the version of the Ice installation is used.
480
+ * @return The new communicator.
481
+ */
482
+ ICE_API CommunicatorPtr initialize(int& argc, const wchar_t* argv[],
483
+ const InitializationData& initData = InitializationData(),
484
+ int version = ICE_INT_VERSION);
485
+
486
+ /**
487
+ * Initializes a new communicator.
488
+ * @param argc The number of arguments in argv. Upon return, this argument
489
+ * is updated to reflect the arguments still remaining in argv.
490
+ * @param argv Command-line arguments, possibly containing
491
+ * options to set properties. If the arguments include
492
+ * a <code>--Ice.Config</code> option, the corresponding configuration
493
+ * files are parsed. If the same property is set in a configuration
494
+ * file and in the arguments, the arguments take precedence.
495
+ * Recognized options are removed from this vector upon return.
496
+ * @param initData Configuration data for the new Communicator.
497
+ * @param version Indicates the Ice version with which the application is compatible. If not
498
+ * specified, the version of the Ice installation is used.
499
+ * @return The new communicator.
500
+ */
150
501
  inline CommunicatorPtr initialize(int& argc, wchar_t* argv[], const InitializationData& initData = InitializationData(),
151
502
  int version = ICE_INT_VERSION)
152
503
  {
153
504
  return initialize(argc, const_cast<const wchar_t**>(argv), initData, version);
154
505
  }
155
506
 
156
- ICE_API CommunicatorPtr initialize(int&, const wchar_t*[], ICE_CONFIG_FILE_STRING, int = ICE_INT_VERSION);
507
+ /**
508
+ * Initializes a new communicator.
509
+ * @param argc The number of arguments in argv. Upon return, this argument
510
+ * is updated to reflect the arguments still remaining in argv.
511
+ * @param argv Command-line arguments, possibly containing
512
+ * options to set properties. If the arguments include
513
+ * a <code>--Ice.Config</code> option, the corresponding configuration
514
+ * files are parsed. If the same property is set in a configuration
515
+ * file and in the arguments, the arguments take precedence.
516
+ * Recognized options are removed from this vector upon return.
517
+ * @param configFile The name of an Ice configuration file.
518
+ * @param version Indicates the Ice version with which the application is compatible. If not
519
+ * specified, the version of the Ice installation is used.
520
+ * @return The new communicator.
521
+ */
522
+ ICE_API CommunicatorPtr initialize(int& argc, const wchar_t* argv[], ICE_CONFIG_FILE_STRING configFile,
523
+ int version = ICE_INT_VERSION);
524
+
525
+ /**
526
+ * Initializes a new communicator.
527
+ * @param argc The number of arguments in argv. Upon return, this argument
528
+ * is updated to reflect the arguments still remaining in argv.
529
+ * @param argv Command-line arguments, possibly containing
530
+ * options to set properties. If the arguments include
531
+ * a <code>--Ice.Config</code> option, the corresponding configuration
532
+ * files are parsed. If the same property is set in a configuration
533
+ * file and in the arguments, the arguments take precedence.
534
+ * Recognized options are removed from this vector upon return.
535
+ * @param configFile The name of an Ice configuration file.
536
+ * @param version Indicates the Ice version with which the application is compatible. If not
537
+ * specified, the version of the Ice installation is used.
538
+ * @return The new communicator.
539
+ */
157
540
  inline CommunicatorPtr initialize(int& argc, wchar_t* argv[], ICE_CONFIG_FILE_STRING configFile,
158
541
  int version = ICE_INT_VERSION)
159
542
  {
@@ -161,102 +544,373 @@ inline CommunicatorPtr initialize(int& argc, wchar_t* argv[], ICE_CONFIG_FILE_ST
161
544
  }
162
545
  #endif
163
546
 
164
- ICE_API CommunicatorPtr initialize(StringSeq&, const InitializationData& = InitializationData(),
165
- int = ICE_INT_VERSION);
166
-
167
- ICE_API CommunicatorPtr initialize(StringSeq&, ICE_CONFIG_FILE_STRING, int = ICE_INT_VERSION);
168
-
169
- ICE_API CommunicatorPtr initialize(const InitializationData& = InitializationData(),
170
- int = ICE_INT_VERSION);
171
-
172
- ICE_API CommunicatorPtr initialize(ICE_CONFIG_FILE_STRING, int = ICE_INT_VERSION);
173
-
547
+ /**
548
+ * Initializes a new communicator.
549
+ * @param seq Command-line arguments, possibly containing
550
+ * options to set properties. If the arguments include
551
+ * a <code>--Ice.Config</code> option, the corresponding configuration
552
+ * files are parsed. If the same property is set in a configuration
553
+ * file and in the arguments, the arguments take precedence.
554
+ * Recognized options are removed from this container upon return.
555
+ * @param initData Configuration data for the new Communicator.
556
+ * @param version Indicates the Ice version with which the application is compatible. If not
557
+ * specified, the version of the Ice installation is used.
558
+ * @return The new communicator.
559
+ */
560
+ ICE_API CommunicatorPtr initialize(StringSeq& seq, const InitializationData& initData = InitializationData(),
561
+ int version = ICE_INT_VERSION);
562
+
563
+ /**
564
+ * Initializes a new communicator.
565
+ * @param seq Command-line arguments, possibly containing
566
+ * options to set properties. If the arguments include
567
+ * a <code>--Ice.Config</code> option, the corresponding configuration
568
+ * files are parsed. If the same property is set in a configuration
569
+ * file and in the arguments, the arguments take precedence.
570
+ * Recognized options are removed from this container upon return.
571
+ * @param configFile The name of an Ice configuration file.
572
+ * @param version Indicates the Ice version with which the application is compatible. If not
573
+ * specified, the version of the Ice installation is used.
574
+ * @return The new communicator.
575
+ */
576
+ ICE_API CommunicatorPtr initialize(StringSeq& seq, ICE_CONFIG_FILE_STRING configFile, int version = ICE_INT_VERSION);
577
+
578
+ /**
579
+ * Initializes a new communicator.
580
+ * @param initData Configuration data for the new Communicator.
581
+ * @param version Indicates the Ice version with which the application is compatible. If not
582
+ * specified, the version of the Ice installation is used.
583
+ * @return The new communicator.
584
+ */
585
+ ICE_API CommunicatorPtr initialize(const InitializationData& initData = InitializationData(),
586
+ int version = ICE_INT_VERSION);
587
+
588
+ /**
589
+ * Initializes a new communicator.
590
+ * @param configFile The name of an Ice configuration file.
591
+ * @param version Indicates the Ice version with which the application is compatible. If not
592
+ * specified, the version of the Ice installation is used.
593
+ * @return The new communicator.
594
+ */
595
+ ICE_API CommunicatorPtr initialize(ICE_CONFIG_FILE_STRING configFile, int version = ICE_INT_VERSION);
596
+
597
+ /**
598
+ * Obtains the per-process logger. This logger is used by all communicators that do not have their
599
+ * own specific logger established at the time a communicator is created.
600
+ * @return The current per-process logger instance.
601
+ */
174
602
  ICE_API LoggerPtr getProcessLogger();
175
- ICE_API void setProcessLogger(const LoggerPtr&);
176
-
177
- typedef Ice::Plugin* (*PluginFactory)(const ::Ice::CommunicatorPtr&, const std::string&, const ::Ice::StringSeq&);
178
- ICE_API void registerPluginFactory(const std::string&, PluginFactory, bool);
179
603
 
180
- //
181
- // RAII helper class
182
- //
604
+ /**
605
+ * Sets the per-process logger. This logger is used by all communicators that do not have their
606
+ * own specific logger established at the time a communicator is created.
607
+ * @param logger The new per-process logger instance.
608
+ */
609
+ ICE_API void setProcessLogger(const LoggerPtr& logger);
610
+
611
+ /**
612
+ * A plug-in factory function is responsible for creating an Ice plug-in.
613
+ * @param communicator The communicator in which the plug-in will be installed.
614
+ * @param name The name assigned to the plug-in.
615
+ * @param args Additional arguments included in the plug-in's configuration.
616
+ * @return The new plug-in object. Returning nil will cause the run time to raise PluginInitializationException.
617
+ */
618
+ typedef Ice::Plugin* (*PluginFactory)(const ::Ice::CommunicatorPtr& communicator, const std::string& name,
619
+ const ::Ice::StringSeq& args);
620
+
621
+ /**
622
+ * Manually registers a plug-in factory function.
623
+ * @param name The name assigned to the plug-in.
624
+ * @param factory The factory function.
625
+ * @param loadOnInit If true, the plug-in is always loaded (created) during communicator initialization,
626
+ * even if Ice.Plugin.name is not set. When false, the plug-in is loaded (created) during communication
627
+ * initialization only if Ice.Plugin.name is set to a non-empty value (e.g.: Ice.Plugin.IceSSL=1).
628
+ */
629
+ ICE_API void registerPluginFactory(const std::string& name, PluginFactory factory, bool loadOnInit);
630
+
631
+ /**
632
+ * A helper class that uses Resource Acquisition Is Initialization (RAII) to initialize and hold a
633
+ * communicator instance, and automatically destroy the communicator when the holder goes out of scope.
634
+ * \headerfile Ice/Ice.h
635
+ */
183
636
  class ICE_API CommunicatorHolder
184
637
  {
185
638
  public:
186
639
 
187
- //
188
- // Empty holder
189
- //
640
+ /**
641
+ * The holder's initial state is empty.
642
+ */
190
643
  CommunicatorHolder();
191
644
 
192
645
  #ifdef ICE_CPP11_MAPPING
193
646
 
194
- //
195
- // Call initialize to create communicator with the provided args
196
- // (all except default ctor above)
197
- //
198
- //
647
+ /**
648
+ * Calls initialize to create a communicator with the provided arguments.
649
+ * This constructor accepts all of the same overloaded argument styles as
650
+ * initialize.
651
+ */
199
652
  template<class... T>
200
653
  explicit CommunicatorHolder(T&&... args) :
201
654
  _communicator(std::move(initialize(std::forward<T>(args)...)))
202
655
  {
203
656
  }
204
657
 
205
- //
206
- // Adopt communicator
207
- //
208
- explicit CommunicatorHolder(std::shared_ptr<Communicator>);
209
- CommunicatorHolder& operator=(std::shared_ptr<Communicator>);
658
+ /**
659
+ * Adopts the given communicator.
660
+ * @param communicator The new communicator instance to hold.
661
+ */
662
+ CommunicatorHolder(std::shared_ptr<Communicator> communicator);
210
663
 
211
- CommunicatorHolder(const CommunicatorHolder&) = delete;
664
+ /**
665
+ * Adopts the given communicator. If this holder currently holds a communicator,
666
+ * it will be destroyed.
667
+ * @param communicator The new communicator instance to hold.
668
+ */
669
+ CommunicatorHolder& operator=(std::shared_ptr<Communicator> communicator);
212
670
 
671
+ CommunicatorHolder(const CommunicatorHolder&) = delete;
213
672
  CommunicatorHolder(CommunicatorHolder&&) = default;
214
- CommunicatorHolder& operator=(CommunicatorHolder&&);
215
673
 
674
+ /**
675
+ * Adopts the communicator in the given holder. If this holder currently holds a communicator,
676
+ * it will be destroyed.
677
+ * @param holder The holder from which to adopt a communicator.
678
+ */
679
+ CommunicatorHolder& operator=(CommunicatorHolder&& holder);
680
+
681
+ /**
682
+ * Determines whether the holder contains an instance.
683
+ * @return True if the holder currently holds an instance, false otherwise.
684
+ */
216
685
  explicit operator bool() const;
217
686
 
218
687
  #else // C++98 mapping
219
688
 
220
- //
221
- // Call initialize to create communicator with the provided args
222
- //
223
- CommunicatorHolder(int&, const char*[], const InitializationData& = InitializationData(), int = ICE_INT_VERSION);
224
- CommunicatorHolder(int&, char*[], const InitializationData& = InitializationData(), int = ICE_INT_VERSION);
225
- CommunicatorHolder(int&, const char*[], const char*, int = ICE_INT_VERSION);
226
- CommunicatorHolder(int&, char*[], const char*, int = ICE_INT_VERSION);
689
+ /**
690
+ * Initializes a new communicator.
691
+ * @param argc The number of arguments in argv. Upon return, this argument
692
+ * is updated to reflect the arguments still remaining in argv.
693
+ * @param argv Command-line arguments, possibly containing
694
+ * options to set properties. If the arguments include
695
+ * a <code>--Ice.Config</code> option, the corresponding configuration
696
+ * files are parsed. If the same property is set in a configuration
697
+ * file and in the arguments, the arguments take precedence.
698
+ * Recognized options are removed from this vector upon return.
699
+ * @param initData Configuration data for the new Communicator.
700
+ * @param version Indicates the Ice version with which the application is compatible. If not
701
+ * specified, the version of the Ice installation is used.
702
+ */
703
+ CommunicatorHolder(int& argc, const char* argv[], const InitializationData& initData = InitializationData(),
704
+ int version = ICE_INT_VERSION);
705
+
706
+ /**
707
+ * Initializes a new communicator.
708
+ * @param argc The number of arguments in argv. Upon return, this argument
709
+ * is updated to reflect the arguments still remaining in argv.
710
+ * @param argv Command-line arguments, possibly containing
711
+ * options to set properties. If the arguments include
712
+ * a <code>--Ice.Config</code> option, the corresponding configuration
713
+ * files are parsed. If the same property is set in a configuration
714
+ * file and in the arguments, the arguments take precedence.
715
+ * Recognized options are removed from this vector upon return.
716
+ * @param initData Configuration data for the new Communicator.
717
+ * @param version Indicates the Ice version with which the application is compatible. If not
718
+ * specified, the version of the Ice installation is used.
719
+ */
720
+ CommunicatorHolder(int& argc, char* argv[], const InitializationData& initData = InitializationData(),
721
+ int version = ICE_INT_VERSION);
722
+
723
+ /**
724
+ * Initializes a new communicator.
725
+ * @param argc The number of arguments in argv. Upon return, this argument
726
+ * is updated to reflect the arguments still remaining in argv.
727
+ * @param argv Command-line arguments, possibly containing
728
+ * options to set properties. If the arguments include
729
+ * a <code>--Ice.Config</code> option, the corresponding configuration
730
+ * files are parsed. If the same property is set in a configuration
731
+ * file and in the arguments, the arguments take precedence.
732
+ * Recognized options are removed from this vector upon return.
733
+ * @param configFile The name of an Ice configuration file.
734
+ * @param version Indicates the Ice version with which the application is compatible. If not
735
+ * specified, the version of the Ice installation is used.
736
+ */
737
+ CommunicatorHolder(int& argc, const char* argv[], const char* configFile, int version = ICE_INT_VERSION);
738
+
739
+ /**
740
+ * Initializes a new communicator.
741
+ * @param argc The number of arguments in argv. Upon return, this argument
742
+ * is updated to reflect the arguments still remaining in argv.
743
+ * @param argv Command-line arguments, possibly containing
744
+ * options to set properties. If the arguments include
745
+ * a <code>--Ice.Config</code> option, the corresponding configuration
746
+ * files are parsed. If the same property is set in a configuration
747
+ * file and in the arguments, the arguments take precedence.
748
+ * Recognized options are removed from this vector upon return.
749
+ * @param configFile The name of an Ice configuration file.
750
+ * @param version Indicates the Ice version with which the application is compatible. If not
751
+ * specified, the version of the Ice installation is used.
752
+ */
753
+ CommunicatorHolder(int& argc, char* argv[], const char* configFile, int version = ICE_INT_VERSION);
227
754
 
228
755
  # ifdef _WIN32
229
- CommunicatorHolder(int&, const wchar_t*[], const InitializationData& = InitializationData(), int = ICE_INT_VERSION);
230
- CommunicatorHolder(int&, wchar_t*[], const InitializationData& = InitializationData(), int = ICE_INT_VERSION);
231
- CommunicatorHolder(int&, const wchar_t*[], const char*, int = ICE_INT_VERSION);
232
- CommunicatorHolder(int&, wchar_t*[], const char*, int = ICE_INT_VERSION);
756
+ /**
757
+ * Initializes a new communicator.
758
+ * @param argc The number of arguments in argv. Upon return, this argument
759
+ * is updated to reflect the arguments still remaining in argv.
760
+ * @param argv Command-line arguments, possibly containing
761
+ * options to set properties. If the arguments include
762
+ * a <code>--Ice.Config</code> option, the corresponding configuration
763
+ * files are parsed. If the same property is set in a configuration
764
+ * file and in the arguments, the arguments take precedence.
765
+ * Recognized options are removed from this vector upon return.
766
+ * @param initData Configuration data for the new Communicator.
767
+ * @param version Indicates the Ice version with which the application is compatible. If not
768
+ * specified, the version of the Ice installation is used.
769
+ */
770
+ CommunicatorHolder(int& argc, const wchar_t* argv[], const InitializationData& initData = InitializationData(),
771
+ int version = ICE_INT_VERSION);
772
+
773
+ /**
774
+ * Initializes a new communicator.
775
+ * @param argc The number of arguments in argv. Upon return, this argument
776
+ * is updated to reflect the arguments still remaining in argv.
777
+ * @param argv Command-line arguments, possibly containing
778
+ * options to set properties. If the arguments include
779
+ * a <code>--Ice.Config</code> option, the corresponding configuration
780
+ * files are parsed. If the same property is set in a configuration
781
+ * file and in the arguments, the arguments take precedence.
782
+ * Recognized options are removed from this vector upon return.
783
+ * @param initData Configuration data for the new Communicator.
784
+ * @param version Indicates the Ice version with which the application is compatible. If not
785
+ * specified, the version of the Ice installation is used.
786
+ */
787
+ CommunicatorHolder(int& argc, wchar_t* argv[], const InitializationData& initData = InitializationData(),
788
+ int version = ICE_INT_VERSION);
789
+
790
+ /**
791
+ * Initializes a new communicator.
792
+ * @param argc The number of arguments in argv. Upon return, this argument
793
+ * is updated to reflect the arguments still remaining in argv.
794
+ * @param argv Command-line arguments, possibly containing
795
+ * options to set properties. If the arguments include
796
+ * a <code>--Ice.Config</code> option, the corresponding configuration
797
+ * files are parsed. If the same property is set in a configuration
798
+ * file and in the arguments, the arguments take precedence.
799
+ * Recognized options are removed from this vector upon return.
800
+ * @param configFile The name of an Ice configuration file.
801
+ * @param version Indicates the Ice version with which the application is compatible. If not
802
+ * specified, the version of the Ice installation is used.
803
+ */
804
+ CommunicatorHolder(int& argc, const wchar_t* argv[], const char* configFile, int version = ICE_INT_VERSION);
805
+
806
+ /**
807
+ * Initializes a new communicator.
808
+ * @param argc The number of arguments in argv. Upon return, this argument
809
+ * is updated to reflect the arguments still remaining in argv.
810
+ * @param argv Command-line arguments, possibly containing
811
+ * options to set properties. If the arguments include
812
+ * a <code>--Ice.Config</code> option, the corresponding configuration
813
+ * files are parsed. If the same property is set in a configuration
814
+ * file and in the arguments, the arguments take precedence.
815
+ * Recognized options are removed from this vector upon return.
816
+ * @param configFile The name of an Ice configuration file.
817
+ * @param version Indicates the Ice version with which the application is compatible. If not
818
+ * specified, the version of the Ice installation is used.
819
+ */
820
+ CommunicatorHolder(int& argc, wchar_t* argv[], const char* configFile, int version = ICE_INT_VERSION);
233
821
  # endif
234
822
 
235
- explicit CommunicatorHolder(StringSeq&, const InitializationData& = InitializationData(), int = ICE_INT_VERSION);
236
- CommunicatorHolder(StringSeq&, const char*, int = ICE_INT_VERSION);
237
-
238
- explicit CommunicatorHolder(const InitializationData&, int = ICE_INT_VERSION);
239
- explicit CommunicatorHolder(const char*, int = ICE_INT_VERSION);
240
-
241
- //
242
- // Adopt communicator
243
- //
244
- explicit CommunicatorHolder(const CommunicatorPtr&);
245
- CommunicatorHolder& operator=(const CommunicatorPtr&);
246
-
823
+ /**
824
+ * Initializes a new communicator.
825
+ * @param seq Command-line arguments, possibly containing
826
+ * options to set properties. If the arguments include
827
+ * a <code>--Ice.Config</code> option, the corresponding configuration
828
+ * files are parsed. If the same property is set in a configuration
829
+ * file and in the arguments, the arguments take precedence.
830
+ * Recognized options are removed from this container upon return.
831
+ * @param initData Configuration data for the new Communicator.
832
+ * @param version Indicates the Ice version with which the application is compatible. If not
833
+ * specified, the version of the Ice installation is used.
834
+ */
835
+ explicit CommunicatorHolder(StringSeq& seq, const InitializationData& initData = InitializationData(),
836
+ int version = ICE_INT_VERSION);
837
+
838
+ /**
839
+ * Initializes a new communicator.
840
+ * @param seq Command-line arguments, possibly containing
841
+ * options to set properties. If the arguments include
842
+ * a <code>--Ice.Config</code> option, the corresponding configuration
843
+ * files are parsed. If the same property is set in a configuration
844
+ * file and in the arguments, the arguments take precedence.
845
+ * Recognized options are removed from this container upon return.
846
+ * @param configFile The name of an Ice configuration file.
847
+ * @param version Indicates the Ice version with which the application is compatible. If not
848
+ * specified, the version of the Ice installation is used.
849
+ */
850
+ CommunicatorHolder(StringSeq& seq, const char* configFile, int version = ICE_INT_VERSION);
851
+
852
+ /**
853
+ * Initializes a new communicator.
854
+ * @param initData Configuration data for the new Communicator.
855
+ * @param version Indicates the Ice version with which the application is compatible. If not
856
+ * specified, the version of the Ice installation is used.
857
+ */
858
+ explicit CommunicatorHolder(const InitializationData& initData, int version = ICE_INT_VERSION);
859
+
860
+ /**
861
+ * Initializes a new communicator.
862
+ * @param configFile The name of an Ice configuration file.
863
+ * @param version Indicates the Ice version with which the application is compatible. If not
864
+ * specified, the version of the Ice installation is used.
865
+ */
866
+ explicit CommunicatorHolder(const char* configFile, int version = ICE_INT_VERSION);
867
+
868
+ /**
869
+ * Adopts the given communicator.
870
+ * @param communicator The new communicator instance to hold.
871
+ */
872
+ CommunicatorHolder(const CommunicatorPtr& communicator);
873
+
874
+ /**
875
+ * Adopts the given communicator. If this holder currently holds a communicator,
876
+ * it will be destroyed.
877
+ * @param communicator The new communicator instance to hold.
878
+ */
879
+ CommunicatorHolder& operator=(const CommunicatorPtr& communicator);
880
+
881
+ /**
882
+ * Determines whether the holder contains an instance.
883
+ * @return True if the holder currently holds an instance, false otherwise.
884
+ */
247
885
  operator bool() const;
248
886
 
887
+ /// \cond INTERNAL
249
888
  //
250
889
  // Required for successful copy-initialization, but not
251
- // defined as it should always be elided by compiler
890
+ // defined as it should always be elided by the compiler.
252
891
  CommunicatorHolder(const CommunicatorHolder&);
892
+ /// \endcond
253
893
 
254
894
  #endif
255
895
 
256
896
  ~CommunicatorHolder();
257
897
 
898
+ /**
899
+ * Obtains the communicator instance.
900
+ * @return The communicator held by this holder, or nil if the holder is empty.
901
+ */
258
902
  const CommunicatorPtr& communicator() const;
903
+
904
+ /**
905
+ * Obtains the communicator instance.
906
+ * @return The communicator held by this holder, or nil if the holder is empty.
907
+ */
259
908
  const CommunicatorPtr& operator->() const;
909
+
910
+ /**
911
+ * Obtains the communicator instance and clears the reference held by the holder.
912
+ * @return The communicator held by this holder, or nil if the holder is empty.
913
+ */
260
914
  CommunicatorPtr release();
261
915
 
262
916
  private:
@@ -264,8 +918,20 @@ private:
264
918
  CommunicatorPtr _communicator;
265
919
  };
266
920
 
267
- ICE_API Identity stringToIdentity(const std::string&);
268
- ICE_API std::string identityToString(const Identity&, ToStringMode = ICE_ENUM(ToStringMode, Unicode));
921
+ /**
922
+ * Converts a stringified identity into an Identity.
923
+ * @param str The stringified identity.
924
+ * @return An Identity structure containing the name and category components.
925
+ */
926
+ ICE_API Identity stringToIdentity(const std::string& str);
927
+
928
+ /**
929
+ * Converts an Identity structure into a string using the specified mode.
930
+ * @param id The identity structure.
931
+ * @param mode Affects the handling of non-ASCII characters and non-printable ASCII characters.
932
+ * @return The stringified identity.
933
+ */
934
+ ICE_API std::string identityToString(const Identity& id, ToStringMode mode = ICE_ENUM(ToStringMode, Unicode));
269
935
 
270
936
  }
271
937