zeroc-ice 3.6.5 → 3.7.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/ICE_LICENSE +17 -17
- data/LICENSE +12 -12
- data/bin/slice2rb +1 -6
- data/ext/Communicator.cpp +223 -61
- data/ext/Communicator.h +1 -6
- data/ext/Config.h +23 -7
- data/ext/Connection.cpp +108 -76
- data/ext/Connection.h +4 -6
- data/ext/Endpoint.cpp +16 -54
- data/ext/Endpoint.h +1 -6
- data/ext/ImplicitContext.cpp +1 -10
- data/ext/ImplicitContext.h +1 -6
- data/ext/Init.cpp +4 -6
- data/ext/Logger.cpp +1 -6
- data/ext/Logger.h +1 -6
- data/ext/Operation.cpp +38 -54
- data/ext/Operation.h +1 -6
- data/ext/Properties.cpp +3 -8
- data/ext/Properties.h +1 -6
- data/ext/Proxy.cpp +111 -70
- data/ext/Proxy.h +1 -6
- data/ext/Slice.cpp +5 -20
- data/ext/Slice.h +1 -6
- data/ext/Types.cpp +313 -224
- data/ext/Types.h +118 -71
- data/ext/Util.cpp +69 -36
- data/ext/Util.h +117 -42
- data/ext/ValueFactoryManager.cpp +440 -0
- data/ext/ValueFactoryManager.h +95 -0
- data/ext/extconf.rb +52 -48
- data/ext/ice/cpp/include/Ice/Application.h +275 -105
- data/ext/ice/cpp/include/Ice/AsyncResult.h +124 -337
- data/ext/ice/cpp/include/Ice/AsyncResultF.h +4 -7
- data/ext/ice/cpp/include/Ice/BatchRequestInterceptor.h +39 -16
- data/ext/ice/cpp/include/Ice/BatchRequestQueueF.h +1 -6
- data/ext/ice/cpp/include/Ice/Buffer.h +10 -15
- data/ext/ice/cpp/include/Ice/CommunicatorAsync.h +56 -17
- data/ext/ice/cpp/include/Ice/Comparable.h +205 -0
- data/ext/ice/cpp/include/Ice/Config.h +16 -39
- data/ext/ice/cpp/include/Ice/ConnectionAsync.h +203 -16
- data/ext/ice/cpp/include/Ice/ConnectionIF.h +7 -6
- data/ext/ice/cpp/include/Ice/ConsoleUtil.h +23 -0
- data/ext/ice/cpp/include/Ice/DefaultValueFactory.h +57 -0
- data/ext/ice/cpp/include/Ice/DispatchInterceptor.h +20 -12
- data/ext/ice/cpp/include/Ice/Dispatcher.h +35 -19
- data/ext/ice/cpp/include/Ice/DynamicLibrary.h +7 -10
- data/ext/ice/cpp/include/Ice/DynamicLibraryF.h +1 -6
- data/ext/ice/cpp/include/Ice/Exception.h +110 -63
- data/ext/ice/cpp/include/Ice/ExceptionHelpers.h +74 -0
- data/ext/ice/cpp/include/Ice/FactoryTable.h +22 -18
- data/ext/ice/cpp/include/Ice/FactoryTableInit.h +28 -31
- data/ext/ice/cpp/include/Ice/Format.h +17 -18
- data/ext/ice/cpp/include/Ice/Functional.h +38 -38
- data/ext/ice/cpp/include/Ice/GCObject.h +9 -10
- data/ext/ice/cpp/include/Ice/Handle.h +6 -16
- data/ext/ice/cpp/include/Ice/Ice.h +9 -10
- data/ext/ice/cpp/include/Ice/IconvStringConverter.h +377 -0
- data/ext/ice/cpp/include/Ice/Incoming.h +132 -38
- data/ext/ice/cpp/include/Ice/IncomingAsync.h +109 -31
- data/ext/ice/cpp/include/Ice/IncomingAsyncF.h +7 -6
- data/ext/ice/cpp/include/Ice/Initialize.h +872 -60
- data/ext/ice/cpp/include/Ice/InputStream.h +1514 -0
- data/ext/ice/cpp/include/Ice/InstanceF.h +1 -7
- data/ext/ice/cpp/include/Ice/InterfaceByValue.h +57 -0
- data/ext/ice/cpp/include/Ice/LocalObject.h +13 -14
- data/ext/ice/cpp/include/Ice/LocalObjectF.h +1 -6
- data/ext/ice/cpp/include/Ice/LoggerUtil.h +56 -24
- data/ext/ice/cpp/include/Ice/MetricsAdminI.h +124 -71
- data/ext/ice/cpp/include/Ice/MetricsFunctional.h +25 -10
- data/ext/ice/cpp/include/Ice/MetricsObserverI.h +116 -32
- data/ext/ice/cpp/include/Ice/NativePropertiesAdmin.h +61 -30
- data/ext/ice/cpp/include/Ice/Object.h +413 -78
- data/ext/ice/cpp/include/Ice/ObjectF.h +12 -8
- data/ext/ice/cpp/include/Ice/ObserverHelper.h +18 -13
- data/ext/ice/cpp/include/Ice/Optional.h +1114 -0
- data/ext/ice/cpp/include/Ice/OutgoingAsync.h +684 -89
- data/ext/ice/cpp/include/Ice/OutgoingAsyncF.h +12 -11
- data/ext/ice/cpp/include/Ice/OutputStream.h +1092 -0
- data/ext/ice/cpp/include/Ice/Protocol.h +49 -17
- data/ext/ice/cpp/include/Ice/Proxy.h +3438 -745
- data/ext/ice/cpp/include/Ice/ProxyF.h +13 -38
- data/ext/ice/cpp/include/Ice/ProxyFactoryF.h +1 -6
- data/ext/ice/cpp/include/Ice/ProxyHandle.h +43 -55
- data/ext/ice/cpp/include/Ice/ReferenceF.h +1 -6
- data/ext/ice/cpp/include/Ice/RegisterPlugins.h +84 -12
- data/ext/ice/cpp/include/Ice/RequestHandlerF.h +10 -9
- data/ext/ice/cpp/include/Ice/ResponseHandlerF.h +6 -6
- data/ext/ice/cpp/include/Ice/SHA1.h +42 -0
- data/ext/ice/cpp/include/Ice/ServantManagerF.h +1 -6
- data/ext/ice/cpp/include/Ice/Service.h +273 -154
- data/ext/ice/cpp/include/Ice/SliceChecksums.h +5 -6
- data/ext/ice/cpp/include/Ice/SlicedData.h +121 -53
- data/ext/ice/cpp/include/Ice/SlicedDataF.h +17 -11
- data/ext/ice/cpp/include/Ice/StreamHelpers.h +453 -140
- data/ext/ice/cpp/include/Ice/StringConverter.h +78 -0
- data/ext/ice/cpp/include/Ice/ThreadPoolF.h +1 -6
- data/ext/ice/cpp/include/Ice/UUID.h +19 -0
- data/ext/ice/cpp/include/{IceUtil → Ice}/UniquePtr.h +22 -28
- data/ext/ice/cpp/include/Ice/UniqueRef.h +97 -0
- data/ext/ice/cpp/include/Ice/UserExceptionFactory.h +45 -13
- data/ext/ice/cpp/include/Ice/Value.h +139 -0
- data/ext/ice/cpp/include/Ice/ValueF.h +21 -0
- data/ext/ice/cpp/include/IceSSL/Config.h +8 -28
- data/ext/ice/cpp/include/IceSSL/IceSSL.h +17 -11
- data/ext/ice/cpp/include/IceSSL/OpenSSL.h +147 -0
- data/ext/ice/cpp/include/IceSSL/Plugin.h +461 -448
- data/ext/ice/cpp/include/IceSSL/SChannel.h +72 -0
- data/ext/ice/cpp/include/IceSSL/SecureTransport.h +72 -0
- data/ext/ice/cpp/include/IceSSL/UWP.h +62 -0
- data/ext/ice/cpp/include/IceUtil/Atomic.h +7 -14
- data/ext/ice/cpp/include/IceUtil/Cond.h +17 -23
- data/ext/ice/cpp/include/IceUtil/Config.h +166 -46
- data/ext/ice/cpp/include/IceUtil/ConsoleUtil.h +92 -0
- data/ext/ice/cpp/include/IceUtil/CountDownLatch.h +5 -10
- data/ext/ice/cpp/include/IceUtil/CtrlCHandler.h +63 -41
- data/ext/ice/cpp/include/IceUtil/DisableWarnings.h +5 -13
- data/ext/ice/cpp/include/IceUtil/Exception.h +284 -75
- data/ext/ice/cpp/include/IceUtil/FileUtil.h +143 -0
- data/ext/ice/cpp/include/IceUtil/Functional.h +4 -6
- data/ext/ice/cpp/include/IceUtil/Handle.h +11 -16
- data/ext/ice/cpp/include/IceUtil/IceUtil.h +4 -15
- data/ext/ice/cpp/include/IceUtil/InputUtil.h +3 -8
- data/ext/ice/cpp/include/IceUtil/Iterator.h +2 -7
- data/ext/ice/cpp/include/IceUtil/Lock.h +8 -15
- data/ext/ice/cpp/include/IceUtil/Monitor.h +1 -7
- data/ext/ice/cpp/include/IceUtil/Mutex.h +19 -23
- data/ext/ice/cpp/include/IceUtil/MutexProtocol.h +2 -7
- data/ext/ice/cpp/include/IceUtil/MutexPtrLock.h +4 -9
- data/ext/ice/cpp/include/IceUtil/MutexPtrTryLock.h +4 -9
- data/ext/ice/cpp/include/IceUtil/Optional.h +134 -23
- data/ext/ice/cpp/include/IceUtil/Options.h +17 -23
- data/ext/ice/cpp/include/IceUtil/OutputUtil.h +61 -37
- data/ext/ice/cpp/include/IceUtil/PopDisableWarnings.h +6 -11
- data/ext/ice/cpp/include/IceUtil/PushDisableWarnings.h +18 -15
- data/ext/ice/cpp/include/IceUtil/Random.h +39 -8
- data/ext/ice/cpp/include/IceUtil/RecMutex.h +7 -13
- data/ext/ice/cpp/include/IceUtil/ResourceConfig.h +53 -0
- data/ext/ice/cpp/include/IceUtil/ScannerConfig.h +10 -15
- data/ext/ice/cpp/include/IceUtil/ScopedArray.h +8 -7
- data/ext/ice/cpp/include/IceUtil/Shared.h +5 -12
- data/ext/ice/cpp/{src → include}/IceUtil/StopWatch.h +2 -7
- data/ext/ice/cpp/include/IceUtil/StringConverter.h +146 -126
- data/ext/ice/cpp/include/IceUtil/StringUtil.h +32 -26
- data/ext/ice/cpp/include/IceUtil/Thread.h +10 -17
- data/ext/ice/cpp/include/IceUtil/ThreadException.h +33 -47
- data/ext/ice/cpp/include/IceUtil/Time.h +3 -8
- data/ext/ice/cpp/include/IceUtil/Timer.h +18 -18
- data/ext/ice/cpp/include/IceUtil/UUID.h +6 -7
- data/ext/ice/cpp/include/IceUtil/UndefSysMacros.h +1 -6
- data/ext/ice/cpp/include/generated/Ice/BuiltinSequences.h +170 -0
- data/ext/ice/cpp/include/generated/Ice/Communicator.h +1156 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/CommunicatorF.h +51 -16
- data/ext/ice/cpp/include/generated/Ice/Connection.h +1660 -0
- data/ext/ice/cpp/include/generated/Ice/ConnectionF.h +119 -0
- data/ext/ice/cpp/include/generated/Ice/Current.h +322 -0
- data/ext/ice/cpp/include/generated/Ice/Endpoint.h +943 -0
- data/ext/ice/cpp/include/generated/Ice/EndpointF.h +166 -0
- data/ext/ice/cpp/include/generated/Ice/EndpointTypes.h +118 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/FacetMap.h +31 -15
- data/ext/ice/cpp/include/generated/Ice/Identity.h +264 -0
- data/ext/ice/cpp/include/generated/Ice/ImplicitContext.h +278 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/ImplicitContextF.h +51 -16
- data/ext/ice/cpp/include/generated/Ice/Instrumentation.h +1143 -0
- data/ext/ice/cpp/include/generated/Ice/InstrumentationF.h +128 -0
- data/ext/ice/cpp/include/generated/Ice/LocalException.h +7041 -0
- data/ext/ice/cpp/include/generated/Ice/Locator.h +3850 -0
- data/ext/ice/cpp/include/generated/Ice/LocatorF.h +147 -0
- data/ext/ice/cpp/include/generated/Ice/Logger.h +231 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/LoggerF.h +51 -16
- data/ext/ice/cpp/include/generated/Ice/Metrics.h +4717 -0
- data/ext/ice/cpp/include/generated/Ice/ObjectAdapter.h +1175 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/ObjectAdapterF.h +51 -16
- data/ext/ice/cpp/include/generated/Ice/ObjectFactory.h +197 -0
- data/ext/ice/cpp/include/generated/Ice/Plugin.h +306 -0
- data/ext/ice/cpp/include/generated/Ice/PluginF.h +110 -0
- data/ext/ice/cpp/include/generated/Ice/Process.h +971 -0
- data/ext/ice/cpp/include/generated/Ice/ProcessF.h +125 -0
- data/ext/ice/cpp/include/generated/Ice/Properties.h +446 -0
- data/ext/ice/cpp/include/generated/Ice/PropertiesAdmin.h +1360 -0
- data/ext/ice/cpp/include/generated/Ice/PropertiesF.h +134 -0
- data/ext/ice/cpp/include/generated/Ice/RemoteLogger.h +2689 -0
- data/ext/ice/cpp/include/generated/Ice/Router.h +1838 -0
- data/ext/ice/cpp/include/generated/Ice/RouterF.h +125 -0
- data/ext/ice/cpp/include/generated/Ice/ServantLocator.h +299 -0
- data/ext/ice/cpp/include/{Ice → generated/Ice}/ServantLocatorF.h +51 -16
- data/ext/ice/cpp/include/{Ice → generated/Ice}/SliceChecksumDict.h +34 -14
- data/ext/ice/cpp/include/generated/Ice/ValueFactory.h +318 -0
- data/ext/ice/cpp/include/generated/Ice/Version.h +357 -0
- data/ext/ice/cpp/include/generated/IceSSL/ConnectionInfo.h +223 -0
- data/ext/ice/cpp/include/generated/IceSSL/ConnectionInfoF.h +101 -0
- data/ext/ice/cpp/include/generated/IceSSL/EndpointInfo.h +181 -0
- data/ext/ice/cpp/src/Ice/ACM.cpp +38 -27
- data/ext/ice/cpp/src/Ice/ACM.h +9 -7
- data/ext/ice/cpp/src/Ice/ACMF.h +30 -0
- data/ext/ice/cpp/src/Ice/Acceptor.cpp +6 -6
- data/ext/ice/cpp/src/Ice/Acceptor.h +4 -8
- data/ext/ice/cpp/src/Ice/AcceptorF.h +1 -6
- data/ext/ice/cpp/src/Ice/ArgVector.cpp +59 -0
- data/ext/ice/cpp/src/Ice/ArgVector.h +36 -0
- data/ext/ice/cpp/src/Ice/AsyncResult.cpp +15 -544
- data/ext/ice/cpp/src/Ice/Base64.cpp +22 -28
- data/ext/ice/cpp/src/Ice/Base64.h +1 -6
- data/ext/ice/cpp/src/Ice/BatchRequestQueue.cpp +41 -18
- data/ext/ice/cpp/src/Ice/BatchRequestQueue.h +15 -15
- data/ext/ice/cpp/src/Ice/Buffer.cpp +75 -18
- data/ext/ice/cpp/src/Ice/BuiltinSequences.cpp +21 -12
- data/ext/ice/cpp/src/Ice/CollocatedRequestHandler.cpp +86 -197
- data/ext/ice/cpp/src/Ice/CollocatedRequestHandler.h +17 -23
- data/ext/ice/cpp/src/Ice/Communicator.cpp +43 -15
- data/ext/ice/cpp/src/Ice/CommunicatorF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/CommunicatorI.cpp +318 -117
- data/ext/ice/cpp/src/Ice/CommunicatorI.h +95 -40
- data/ext/ice/cpp/src/{IceUtil → Ice}/Cond.cpp +3 -8
- data/ext/ice/cpp/src/Ice/ConnectRequestHandler.cpp +55 -122
- data/ext/ice/cpp/src/Ice/ConnectRequestHandler.h +15 -31
- data/ext/ice/cpp/src/Ice/ConnectRequestHandlerF.h +6 -7
- data/ext/ice/cpp/src/Ice/Connection.cpp +111 -20
- data/ext/ice/cpp/src/Ice/ConnectionF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/ConnectionFactory.cpp +300 -107
- data/ext/ice/cpp/src/Ice/ConnectionFactory.h +44 -28
- data/ext/ice/cpp/src/Ice/ConnectionFactoryF.h +30 -0
- data/ext/ice/cpp/src/Ice/ConnectionI.cpp +785 -713
- data/ext/ice/cpp/src/Ice/ConnectionI.h +105 -80
- data/ext/ice/cpp/src/Ice/ConnectionRequestHandler.cpp +2 -20
- data/ext/ice/cpp/src/Ice/ConnectionRequestHandler.h +5 -9
- data/ext/ice/cpp/src/Ice/Connector.cpp +6 -6
- data/ext/ice/cpp/src/Ice/Connector.h +4 -8
- data/ext/ice/cpp/src/Ice/ConnectorF.h +1 -6
- data/ext/ice/cpp/src/{IceUtil → Ice}/CountDownLatch.cpp +4 -9
- data/ext/ice/cpp/src/Ice/Current.cpp +30 -12
- data/ext/ice/cpp/src/Ice/DefaultsAndOverrides.cpp +10 -16
- data/ext/ice/cpp/src/Ice/DefaultsAndOverrides.h +1 -6
- data/ext/ice/cpp/src/Ice/DefaultsAndOverridesF.h +1 -6
- data/ext/ice/cpp/src/Ice/DispatchInterceptor.cpp +13 -25
- data/ext/ice/cpp/src/Ice/DynamicLibrary.cpp +34 -28
- data/ext/ice/cpp/src/Ice/Endpoint.cpp +107 -19
- data/ext/ice/cpp/src/Ice/EndpointF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/EndpointFactory.cpp +152 -6
- data/ext/ice/cpp/src/Ice/EndpointFactory.h +72 -11
- data/ext/ice/cpp/src/Ice/EndpointFactoryF.h +1 -6
- data/ext/ice/cpp/src/Ice/EndpointFactoryManager.cpp +41 -36
- data/ext/ice/cpp/src/Ice/EndpointFactoryManager.h +10 -9
- data/ext/ice/cpp/src/Ice/EndpointFactoryManagerF.h +1 -6
- data/ext/ice/cpp/src/Ice/EndpointI.cpp +18 -7
- data/ext/ice/cpp/src/Ice/EndpointI.h +39 -18
- data/ext/ice/cpp/src/Ice/EndpointIF.h +18 -10
- data/ext/ice/cpp/src/Ice/EndpointTypes.cpp +19 -12
- data/ext/ice/cpp/src/Ice/EventHandler.cpp +6 -9
- data/ext/ice/cpp/src/Ice/EventHandler.h +13 -13
- data/ext/ice/cpp/src/Ice/EventHandlerF.h +5 -7
- data/ext/ice/cpp/src/Ice/Exception.cpp +102 -98
- data/ext/ice/cpp/src/Ice/FacetMap.cpp +21 -12
- data/ext/ice/cpp/src/Ice/FactoryTable.cpp +37 -33
- data/ext/ice/cpp/src/Ice/FactoryTableInit.cpp +2 -9
- data/ext/ice/cpp/src/Ice/GCObject.cpp +29 -31
- data/ext/ice/cpp/src/Ice/HashUtil.h +3 -9
- data/ext/ice/cpp/src/Ice/HttpParser.cpp +1 -7
- data/ext/ice/cpp/src/Ice/HttpParser.h +1 -6
- data/ext/ice/cpp/src/Ice/IPEndpointI.cpp +128 -111
- data/ext/ice/cpp/src/Ice/IPEndpointI.h +23 -19
- data/ext/ice/cpp/src/Ice/IPEndpointIF.h +6 -7
- data/ext/ice/cpp/src/Ice/IconvStringConverter.cpp +51 -0
- data/ext/ice/cpp/src/Ice/Identity.cpp +25 -16
- data/ext/ice/cpp/src/Ice/ImplicitContext.cpp +41 -13
- data/ext/ice/cpp/src/Ice/ImplicitContextF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/ImplicitContextI.cpp +11 -28
- data/ext/ice/cpp/src/Ice/ImplicitContextI.h +7 -10
- data/ext/ice/cpp/src/Ice/Incoming.cpp +284 -255
- data/ext/ice/cpp/src/Ice/IncomingAsync.cpp +104 -214
- data/ext/ice/cpp/src/Ice/IncomingRequest.h +5 -9
- data/ext/ice/cpp/src/Ice/Initialize.cpp +309 -193
- data/ext/ice/cpp/src/Ice/InputStream.cpp +2726 -0
- data/ext/ice/cpp/src/Ice/Instance.cpp +243 -262
- data/ext/ice/cpp/src/Ice/Instance.h +30 -23
- data/ext/ice/cpp/src/Ice/Instrumentation.cpp +137 -23
- data/ext/ice/cpp/src/Ice/InstrumentationF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/InstrumentationI.cpp +118 -105
- data/ext/ice/cpp/src/Ice/InstrumentationI.h +30 -36
- data/ext/ice/cpp/src/Ice/LocalException.cpp +1191 -422
- data/ext/ice/cpp/src/Ice/LocalObject.cpp +1 -7
- data/ext/ice/cpp/src/Ice/Locator.cpp +1282 -1222
- data/ext/ice/cpp/src/Ice/LocatorF.cpp +30 -12
- data/ext/ice/cpp/src/Ice/LocatorInfo.cpp +150 -186
- data/ext/ice/cpp/src/Ice/LocatorInfo.h +31 -36
- data/ext/ice/cpp/src/Ice/LocatorInfoF.h +1 -6
- data/ext/ice/cpp/src/Ice/Logger.cpp +39 -12
- data/ext/ice/cpp/src/Ice/LoggerAdminI.cpp +182 -88
- data/ext/ice/cpp/src/Ice/LoggerAdminI.h +4 -9
- data/ext/ice/cpp/src/Ice/LoggerF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/LoggerI.cpp +26 -55
- data/ext/ice/cpp/src/Ice/LoggerI.h +7 -18
- data/ext/ice/cpp/src/Ice/LoggerUtil.cpp +10 -17
- data/ext/ice/cpp/src/Ice/Metrics.cpp +1280 -1107
- data/ext/ice/cpp/src/Ice/MetricsAdminI.cpp +58 -33
- data/ext/ice/cpp/src/Ice/MetricsObserverI.cpp +1 -7
- data/ext/ice/cpp/src/Ice/Network.cpp +753 -408
- data/ext/ice/cpp/src/Ice/Network.h +99 -36
- data/ext/ice/cpp/src/Ice/NetworkF.h +2 -7
- data/ext/ice/cpp/src/Ice/NetworkProxy.cpp +20 -19
- data/ext/ice/cpp/src/Ice/NetworkProxy.h +5 -7
- data/ext/ice/cpp/src/Ice/NetworkProxyF.h +1 -6
- data/ext/ice/cpp/src/Ice/OSLogLoggerI.cpp +57 -0
- data/ext/ice/cpp/src/Ice/OSLogLoggerI.h +40 -0
- data/ext/ice/cpp/src/Ice/Object.cpp +227 -232
- data/ext/ice/cpp/src/Ice/ObjectAdapter.cpp +45 -13
- data/ext/ice/cpp/src/Ice/ObjectAdapterF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/ObjectAdapterFactory.cpp +83 -33
- data/ext/ice/cpp/src/Ice/ObjectAdapterFactory.h +13 -12
- data/ext/ice/cpp/src/Ice/ObjectAdapterFactoryF.h +25 -0
- data/ext/ice/cpp/src/Ice/ObjectAdapterI.cpp +298 -191
- data/ext/ice/cpp/src/Ice/ObjectAdapterI.h +44 -39
- data/ext/ice/cpp/src/Ice/ObjectFactory.cpp +41 -13
- data/ext/ice/cpp/src/Ice/ObserverHelper.cpp +9 -37
- data/ext/ice/cpp/src/Ice/OpaqueEndpointI.cpp +67 -67
- data/ext/ice/cpp/src/Ice/OpaqueEndpointI.h +15 -11
- data/ext/ice/cpp/src/Ice/OutgoingAsync.cpp +801 -366
- data/ext/ice/cpp/src/Ice/OutputStream.cpp +1367 -0
- data/ext/ice/cpp/src/Ice/Plugin.cpp +52 -14
- data/ext/ice/cpp/src/Ice/PluginF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/PluginManagerI.cpp +27 -51
- data/ext/ice/cpp/src/Ice/PluginManagerI.h +7 -13
- data/ext/ice/cpp/src/Ice/Process.cpp +294 -128
- data/ext/ice/cpp/src/Ice/ProcessF.cpp +30 -12
- data/ext/ice/cpp/src/Ice/Properties.cpp +42 -15
- data/ext/ice/cpp/src/Ice/PropertiesAdmin.cpp +382 -340
- data/ext/ice/cpp/src/Ice/PropertiesAdminI.cpp +83 -24
- data/ext/ice/cpp/src/Ice/PropertiesAdminI.h +29 -10
- data/ext/ice/cpp/src/Ice/PropertiesF.cpp +30 -12
- data/ext/ice/cpp/src/Ice/PropertiesI.cpp +46 -57
- data/ext/ice/cpp/src/Ice/PropertiesI.h +18 -26
- data/ext/ice/cpp/src/Ice/PropertyNames.cpp +112 -19
- data/ext/ice/cpp/src/Ice/PropertyNames.h +4 -7
- data/ext/ice/cpp/src/Ice/Protocol.cpp +6 -19
- data/ext/ice/cpp/src/Ice/ProtocolInstance.cpp +37 -7
- data/ext/ice/cpp/src/Ice/ProtocolInstance.h +9 -25
- data/ext/ice/cpp/src/Ice/ProtocolInstanceF.h +1 -6
- data/ext/ice/cpp/src/Ice/ProtocolPluginFacade.cpp +6 -6
- data/ext/ice/cpp/src/Ice/ProtocolPluginFacade.h +3 -6
- data/ext/ice/cpp/src/Ice/ProtocolPluginFacadeF.h +1 -6
- data/ext/ice/cpp/src/Ice/Proxy.cpp +729 -957
- data/ext/ice/cpp/src/Ice/ProxyFactory.cpp +33 -38
- data/ext/ice/cpp/src/Ice/ProxyFactory.h +16 -16
- data/ext/ice/cpp/src/Ice/Reference.cpp +190 -106
- data/ext/ice/cpp/src/Ice/Reference.h +39 -28
- data/ext/ice/cpp/src/Ice/ReferenceFactory.cpp +69 -118
- data/ext/ice/cpp/src/Ice/ReferenceFactory.h +12 -17
- data/ext/ice/cpp/src/Ice/ReferenceFactoryF.h +1 -6
- data/ext/ice/cpp/src/Ice/RegisterPluginsInit.cpp +19 -9
- data/ext/ice/cpp/src/Ice/RegisterPluginsInit.h +1 -6
- data/ext/ice/cpp/src/Ice/RemoteLogger.cpp +766 -565
- data/ext/ice/cpp/src/Ice/ReplyStatus.h +1 -6
- data/ext/ice/cpp/src/Ice/RequestHandler.cpp +5 -8
- data/ext/ice/cpp/src/Ice/RequestHandler.h +10 -18
- data/ext/ice/cpp/src/Ice/RequestHandlerFactory.cpp +10 -11
- data/ext/ice/cpp/src/Ice/RequestHandlerFactory.h +2 -7
- data/ext/ice/cpp/src/Ice/ResponseHandler.cpp +3 -11
- data/ext/ice/cpp/src/Ice/ResponseHandler.h +16 -12
- data/ext/ice/cpp/src/Ice/RetryQueue.cpp +12 -20
- data/ext/ice/cpp/src/Ice/RetryQueue.h +7 -11
- data/ext/ice/cpp/src/Ice/RetryQueueF.h +1 -6
- data/ext/ice/cpp/src/Ice/Router.cpp +614 -492
- data/ext/ice/cpp/src/Ice/RouterF.cpp +30 -12
- data/ext/ice/cpp/src/Ice/RouterInfo.cpp +93 -99
- data/ext/ice/cpp/src/Ice/RouterInfo.h +42 -38
- data/ext/ice/cpp/src/Ice/RouterInfoF.h +1 -6
- data/ext/ice/cpp/src/{IceUtil → Ice}/SHA1.cpp +23 -28
- data/ext/ice/cpp/src/Ice/Selector.cpp +948 -855
- data/ext/ice/cpp/src/Ice/Selector.h +100 -152
- data/ext/ice/cpp/src/Ice/ServantLocator.cpp +41 -13
- data/ext/ice/cpp/src/Ice/ServantLocatorF.cpp +28 -11
- data/ext/ice/cpp/src/Ice/ServantManager.cpp +24 -45
- data/ext/ice/cpp/src/Ice/ServantManager.h +1 -6
- data/ext/ice/cpp/src/Ice/SharedContext.h +2 -7
- data/ext/ice/cpp/src/Ice/SliceChecksumDict.cpp +21 -12
- data/ext/ice/cpp/src/Ice/SliceChecksums.cpp +2 -7
- data/ext/ice/cpp/src/Ice/SlicedData.cpp +72 -25
- data/ext/ice/cpp/src/Ice/StreamSocket.cpp +208 -76
- data/ext/ice/cpp/src/Ice/StreamSocket.h +13 -9
- data/ext/ice/cpp/src/Ice/StringConverterPlugin.cpp +57 -22
- data/ext/ice/cpp/src/Ice/StringUtil.h +30 -0
- data/ext/ice/cpp/src/Ice/SysLoggerI.cpp +6 -7
- data/ext/ice/cpp/src/Ice/SysLoggerI.h +2 -8
- data/ext/ice/cpp/src/Ice/SystemdJournalI.cpp +66 -0
- data/ext/ice/cpp/src/Ice/SystemdJournalI.h +39 -0
- data/ext/ice/cpp/src/Ice/TcpAcceptor.cpp +169 -49
- data/ext/ice/cpp/src/Ice/TcpAcceptor.h +12 -10
- data/ext/ice/cpp/src/Ice/TcpConnector.cpp +6 -12
- data/ext/ice/cpp/src/Ice/TcpConnector.h +1 -7
- data/ext/ice/cpp/src/Ice/TcpEndpointI.cpp +51 -46
- data/ext/ice/cpp/src/Ice/TcpEndpointI.h +12 -14
- data/ext/ice/cpp/src/Ice/TcpTransceiver.cpp +17 -32
- data/ext/ice/cpp/src/Ice/TcpTransceiver.h +7 -15
- data/ext/ice/cpp/src/{IceUtil → Ice}/Thread.cpp +41 -54
- data/ext/ice/cpp/src/Ice/ThreadPool.cpp +242 -274
- data/ext/ice/cpp/src/Ice/ThreadPool.h +46 -48
- data/ext/ice/cpp/src/{IceUtil → Ice}/Timer.cpp +38 -26
- data/ext/ice/cpp/src/Ice/TraceLevels.cpp +2 -7
- data/ext/ice/cpp/src/Ice/TraceLevels.h +1 -6
- data/ext/ice/cpp/src/Ice/TraceLevelsF.h +2 -7
- data/ext/ice/cpp/src/Ice/TraceUtil.cpp +53 -36
- data/ext/ice/cpp/src/Ice/TraceUtil.h +13 -11
- data/ext/ice/cpp/src/Ice/Transceiver.cpp +1 -7
- data/ext/ice/cpp/src/Ice/Transceiver.h +8 -12
- data/ext/ice/cpp/src/Ice/TransceiverF.h +3 -8
- data/ext/ice/cpp/src/Ice/UdpConnector.cpp +5 -13
- data/ext/ice/cpp/src/Ice/UdpConnector.h +1 -7
- data/ext/ice/cpp/src/Ice/UdpEndpointI.cpp +118 -60
- data/ext/ice/cpp/src/Ice/UdpEndpointI.h +13 -10
- data/ext/ice/cpp/src/Ice/UdpTransceiver.cpp +177 -236
- data/ext/ice/cpp/src/Ice/UdpTransceiver.h +15 -22
- data/ext/ice/cpp/src/Ice/Value.cpp +76 -0
- data/ext/ice/cpp/src/Ice/ValueFactory.cpp +83 -0
- data/ext/ice/cpp/src/Ice/ValueFactoryManagerI.cpp +61 -0
- data/ext/ice/cpp/src/Ice/ValueFactoryManagerI.h +37 -0
- data/ext/ice/cpp/src/Ice/Version.cpp +25 -20
- data/ext/ice/cpp/src/Ice/VirtualShared.h +38 -0
- data/ext/ice/cpp/src/Ice/WSAcceptor.cpp +3 -14
- data/ext/ice/cpp/src/Ice/WSAcceptor.h +3 -12
- data/ext/ice/cpp/src/Ice/WSConnector.cpp +5 -16
- data/ext/ice/cpp/src/Ice/WSConnector.h +3 -11
- data/ext/ice/cpp/src/Ice/WSEndpoint.cpp +188 -89
- data/ext/ice/cpp/src/Ice/WSEndpoint.h +22 -37
- data/ext/ice/cpp/src/Ice/WSTransceiver.cpp +65 -66
- data/ext/ice/cpp/src/Ice/WSTransceiver.h +7 -27
- data/ext/ice/cpp/src/IceDiscovery/IceDiscovery.cpp +596 -281
- data/ext/ice/cpp/src/IceDiscovery/IceDiscovery.h +1383 -543
- data/ext/ice/cpp/src/IceDiscovery/LocatorI.cpp +89 -32
- data/ext/ice/cpp/src/IceDiscovery/LocatorI.h +59 -28
- data/ext/ice/cpp/src/IceDiscovery/LookupI.cpp +315 -66
- data/ext/ice/cpp/src/IceDiscovery/LookupI.h +83 -41
- data/ext/ice/cpp/src/IceDiscovery/PluginI.cpp +57 -64
- data/ext/ice/cpp/src/IceDiscovery/PluginI.h +3 -8
- data/ext/ice/cpp/src/IceLocatorDiscovery/IceLocatorDiscovery.cpp +450 -172
- data/ext/ice/cpp/src/IceLocatorDiscovery/IceLocatorDiscovery.h +863 -406
- data/ext/ice/cpp/src/IceLocatorDiscovery/Plugin.h +47 -0
- data/ext/ice/cpp/src/IceLocatorDiscovery/PluginI.cpp +636 -144
- data/ext/ice/cpp/src/IceSSL/AcceptorI.cpp +20 -173
- data/ext/ice/cpp/src/IceSSL/AcceptorI.h +8 -22
- data/ext/ice/cpp/src/IceSSL/CertificateI.cpp +279 -0
- data/ext/ice/cpp/src/IceSSL/CertificateI.h +64 -0
- data/ext/ice/cpp/src/IceSSL/ConnectionInfo.cpp +42 -17
- data/ext/ice/cpp/src/IceSSL/ConnectionInfoF.cpp +61 -0
- data/ext/ice/cpp/src/IceSSL/ConnectorI.cpp +15 -64
- data/ext/ice/cpp/src/IceSSL/ConnectorI.h +6 -18
- data/ext/ice/cpp/src/IceSSL/EndpointI.cpp +207 -204
- data/ext/ice/cpp/src/IceSSL/EndpointI.h +43 -40
- data/ext/ice/cpp/src/IceSSL/EndpointInfo.cpp +42 -16
- data/ext/ice/cpp/src/IceSSL/Instance.cpp +1 -11
- data/ext/ice/cpp/src/IceSSL/Instance.h +7 -12
- data/ext/ice/cpp/src/IceSSL/InstanceF.h +11 -12
- data/ext/ice/cpp/src/IceSSL/OpenSSLCertificateI.cpp +583 -0
- data/ext/ice/cpp/src/IceSSL/OpenSSLEngine.cpp +134 -115
- data/ext/ice/cpp/src/IceSSL/OpenSSLEngine.h +59 -0
- data/ext/ice/cpp/src/IceSSL/OpenSSLEngineF.h +27 -0
- data/ext/ice/cpp/src/IceSSL/OpenSSLPluginI.cpp +127 -0
- data/ext/ice/cpp/src/IceSSL/OpenSSLTransceiverI.cpp +477 -182
- data/ext/ice/cpp/src/IceSSL/OpenSSLTransceiverI.h +32 -26
- data/ext/ice/cpp/src/IceSSL/OpenSSLUtil.cpp +286 -0
- data/ext/ice/cpp/src/IceSSL/OpenSSLUtil.h +58 -0
- data/ext/ice/cpp/src/IceSSL/PluginI.cpp +71 -46
- data/ext/ice/cpp/src/IceSSL/PluginI.h +13 -23
- data/ext/ice/cpp/src/IceSSL/RFC2253.cpp +9 -60
- data/ext/ice/cpp/src/IceSSL/RFC2253.h +7 -12
- data/ext/ice/cpp/src/IceSSL/SChannelCertificateI.cpp +580 -0
- data/ext/ice/cpp/src/IceSSL/SChannelEngine.cpp +523 -74
- data/ext/ice/cpp/src/IceSSL/SChannelEngine.h +123 -0
- data/ext/ice/cpp/src/IceSSL/SChannelEngineF.h +31 -0
- data/ext/ice/cpp/src/IceSSL/SChannelPluginI.cpp +73 -0
- data/ext/ice/cpp/src/IceSSL/SChannelTransceiverI.cpp +187 -221
- data/ext/ice/cpp/src/IceSSL/SChannelTransceiverI.h +24 -26
- data/ext/ice/cpp/src/IceSSL/SSLEngine.cpp +97 -94
- data/ext/ice/cpp/src/IceSSL/SSLEngine.h +26 -192
- data/ext/ice/cpp/src/IceSSL/SSLEngineF.h +4 -24
- data/ext/ice/cpp/src/IceSSL/SecureTransportCertificateI.cpp +868 -0
- data/ext/ice/cpp/src/IceSSL/SecureTransportEngine.cpp +69 -201
- data/ext/ice/cpp/src/IceSSL/SecureTransportEngine.h +59 -0
- data/ext/ice/cpp/src/IceSSL/SecureTransportEngineF.h +29 -0
- data/ext/ice/cpp/src/IceSSL/SecureTransportPluginI.cpp +75 -0
- data/ext/ice/cpp/src/IceSSL/SecureTransportTransceiverI.cpp +174 -161
- data/ext/ice/cpp/src/IceSSL/SecureTransportTransceiverI.h +29 -33
- data/ext/ice/cpp/src/IceSSL/SecureTransportUtil.cpp +864 -0
- data/ext/ice/cpp/src/IceSSL/SecureTransportUtil.h +45 -0
- data/ext/ice/cpp/src/IceSSL/TrustManager.cpp +12 -22
- data/ext/ice/cpp/src/IceSSL/TrustManager.h +4 -9
- data/ext/ice/cpp/src/IceSSL/TrustManagerF.h +3 -8
- data/ext/ice/cpp/src/IceSSL/UWPCertificateI.cpp +266 -0
- data/ext/ice/cpp/src/IceSSL/UWPEngine.cpp +338 -0
- data/ext/ice/cpp/src/IceSSL/UWPEngine.h +41 -0
- data/ext/ice/cpp/src/IceSSL/UWPEngineF.h +26 -0
- data/ext/ice/cpp/src/IceSSL/UWPPluginI.cpp +89 -0
- data/ext/ice/cpp/src/IceSSL/UWPTransceiverI.cpp +383 -0
- data/ext/ice/cpp/src/IceSSL/UWPTransceiverI.h +71 -0
- data/ext/ice/cpp/src/IceSSL/Util.cpp +71 -1260
- data/ext/ice/cpp/src/IceSSL/Util.h +48 -142
- data/ext/ice/cpp/src/IceUtil/ConsoleUtil.cpp +157 -0
- data/ext/ice/cpp/src/IceUtil/ConvertUTF.cpp +22 -27
- data/ext/ice/cpp/src/IceUtil/ConvertUTF.h +34 -31
- data/ext/ice/cpp/src/IceUtil/CtrlCHandler.cpp +22 -36
- data/ext/ice/cpp/src/IceUtil/FileUtil.cpp +30 -126
- data/ext/ice/cpp/src/IceUtil/InputUtil.cpp +1 -6
- data/ext/ice/cpp/src/IceUtil/MutexProtocol.cpp +1 -6
- data/ext/ice/cpp/src/IceUtil/Options.cpp +20 -33
- data/ext/ice/cpp/src/IceUtil/OutputUtil.cpp +47 -21
- data/ext/ice/cpp/src/IceUtil/Random.cpp +15 -20
- data/ext/ice/cpp/src/IceUtil/RecMutex.cpp +4 -19
- data/ext/ice/cpp/src/IceUtil/Shared.cpp +8 -8
- data/ext/ice/cpp/src/IceUtil/StringConverter.cpp +501 -269
- data/ext/ice/cpp/src/IceUtil/StringUtil.cpp +582 -244
- data/ext/ice/cpp/src/IceUtil/ThreadException.cpp +37 -79
- data/ext/ice/cpp/src/IceUtil/Time.cpp +6 -11
- data/ext/ice/cpp/src/IceUtil/UUID.cpp +17 -22
- data/ext/ice/cpp/src/IceUtil/Unicode.cpp +97 -101
- data/ext/ice/cpp/src/IceUtil/Unicode.h +21 -40
- data/ext/ice/cpp/src/IceUtil/UtilException.cpp +839 -0
- data/ext/ice/cpp/src/Slice/CPlusPlusUtil.cpp +894 -234
- data/ext/ice/cpp/src/Slice/CPlusPlusUtil.h +72 -0
- data/ext/ice/cpp/src/Slice/Checksum.cpp +2 -7
- data/ext/ice/cpp/src/Slice/Checksum.h +21 -0
- data/ext/ice/cpp/src/Slice/FileTracker.cpp +25 -83
- data/ext/ice/cpp/{include → src}/Slice/FileTracker.h +9 -14
- data/ext/ice/cpp/src/Slice/Grammar.cpp +1981 -1944
- data/ext/ice/cpp/src/Slice/Grammar.h +39 -19
- data/ext/ice/cpp/src/Slice/GrammarUtil.h +14 -20
- data/ext/ice/cpp/src/Slice/JavaUtil.cpp +2752 -1948
- data/ext/ice/cpp/src/Slice/JavaUtil.h +398 -0
- data/ext/ice/cpp/src/Slice/MD5.cpp +1 -6
- data/ext/ice/cpp/src/Slice/MD5.h +1 -6
- data/ext/ice/cpp/src/Slice/MD5I.cpp +8 -1
- data/ext/ice/cpp/src/Slice/MD5I.h +1 -1
- data/ext/ice/cpp/src/Slice/PHPUtil.cpp +17 -20
- data/ext/ice/cpp/src/Slice/PHPUtil.h +36 -0
- data/ext/ice/cpp/src/Slice/Parser.cpp +1190 -426
- data/ext/ice/cpp/{include → src}/Slice/Parser.h +143 -91
- data/ext/ice/cpp/src/Slice/Preprocessor.cpp +67 -36
- data/ext/ice/cpp/{include → src}/Slice/Preprocessor.h +8 -18
- data/ext/ice/cpp/src/Slice/Python.cpp +218 -111
- data/ext/ice/cpp/src/Slice/PythonUtil.cpp +787 -699
- data/ext/ice/cpp/src/Slice/PythonUtil.h +70 -0
- data/ext/ice/cpp/src/Slice/Ruby.cpp +42 -43
- data/ext/ice/cpp/src/Slice/RubyUtil.cpp +175 -445
- data/ext/ice/cpp/{include → src}/Slice/RubyUtil.h +6 -11
- data/ext/ice/cpp/src/Slice/Scanner.cpp +390 -399
- data/ext/ice/cpp/src/Slice/{Util.cpp → SliceUtil.cpp} +36 -69
- data/ext/ice/cpp/src/Slice/StringLiteralUtil.cpp +456 -0
- data/ext/ice/cpp/src/Slice/Util.h +50 -0
- data/ice.gemspec +2 -9
- data/lib/Glacier2.rb +1 -6
- data/lib/Glacier2/Metrics.rb +6 -50
- data/lib/Glacier2/PermissionsVerifier.rb +23 -99
- data/lib/Glacier2/PermissionsVerifierF.rb +2 -7
- data/lib/Glacier2/Router.rb +31 -78
- data/lib/Glacier2/RouterF.rb +2 -7
- data/lib/Glacier2/SSLInfo.rb +3 -11
- data/lib/Glacier2/Session.rb +87 -311
- data/lib/Ice.rb +84 -58
- data/lib/Ice/BuiltinSequences.rb +3 -8
- data/lib/Ice/Communicator.rb +54 -61
- data/lib/Ice/CommunicatorF.rb +2 -7
- data/lib/Ice/Connection.rb +152 -166
- data/lib/Ice/ConnectionF.rb +2 -7
- data/lib/Ice/Current.rb +3 -15
- data/lib/Ice/Endpoint.rb +56 -137
- data/lib/Ice/EndpointF.rb +2 -7
- data/lib/Ice/EndpointTypes.rb +2 -11
- data/lib/Ice/FacetMap.rb +3 -8
- data/lib/Ice/Identity.rb +4 -12
- data/lib/Ice/ImplicitContext.rb +4 -38
- data/lib/Ice/ImplicitContextF.rb +2 -7
- data/lib/Ice/Instrumentation.rb +22 -279
- data/lib/Ice/InstrumentationF.rb +2 -7
- data/lib/Ice/LocalException.rb +94 -145
- data/lib/Ice/Locator.rb +50 -169
- data/lib/Ice/LocatorF.rb +2 -7
- data/lib/Ice/Logger.rb +4 -38
- data/lib/Ice/LoggerF.rb +2 -7
- data/lib/Ice/Metrics.rb +60 -420
- data/lib/Ice/ObjectAdapter.rb +29 -0
- data/lib/Ice/ObjectAdapterF.rb +2 -7
- data/lib/Ice/ObjectFactory.rb +4 -34
- data/lib/Ice/Plugin.rb +6 -64
- data/lib/Ice/PluginF.rb +2 -7
- data/lib/Ice/Process.rb +15 -56
- data/lib/Ice/ProcessF.rb +2 -7
- data/lib/Ice/Properties.rb +4 -45
- data/lib/Ice/PropertiesAdmin.rb +18 -60
- data/lib/Ice/PropertiesF.rb +2 -7
- data/lib/Ice/RemoteLogger.rb +33 -119
- data/lib/Ice/Router.rb +28 -105
- data/lib/Ice/RouterF.rb +2 -7
- data/lib/Ice/ServantLocator.rb +26 -0
- data/lib/Ice/ServantLocatorF.rb +24 -0
- data/lib/Ice/SliceChecksumDict.rb +2 -7
- data/lib/Ice/ValueFactory.rb +28 -0
- data/lib/Ice/Version.rb +4 -15
- data/lib/IceBox.rb +1 -6
- data/lib/IceBox/IceBox.rb +43 -152
- data/lib/IceGrid.rb +1 -9
- data/lib/IceGrid/Admin.rb +550 -431
- data/lib/IceGrid/Descriptor.rb +61 -533
- data/lib/IceGrid/Exception.rb +23 -49
- data/lib/IceGrid/FileParser.rb +13 -54
- data/lib/IceGrid/PluginFacade.rb +35 -0
- data/lib/IceGrid/Registry.rb +150 -62
- data/lib/IceGrid/Session.rb +24 -68
- data/lib/IceGrid/UserAccountMapper.rb +13 -54
- data/lib/IcePatch2.rb +1 -6
- data/lib/IcePatch2/FileInfo.rb +4 -15
- data/lib/IcePatch2/FileServer.rb +32 -80
- data/lib/IceStorm.rb +1 -6
- data/lib/IceStorm/IceStorm.rb +78 -210
- data/lib/IceStorm/Metrics.rb +10 -93
- data/slice/Glacier2/Metrics.ice +20 -10
- data/slice/Glacier2/PermissionsVerifier.ice +19 -12
- data/slice/Glacier2/PermissionsVerifierF.ice +16 -9
- data/slice/Glacier2/Router.ice +19 -13
- data/slice/Glacier2/RouterF.ice +16 -9
- data/slice/Glacier2/SSLInfo.ice +17 -10
- data/slice/Glacier2/Session.ice +24 -18
- data/slice/Ice/BuiltinSequences.ice +18 -9
- data/slice/Ice/Communicator.ice +180 -64
- data/slice/Ice/CommunicatorF.ice +18 -9
- data/slice/Ice/Connection.ice +208 -75
- data/slice/Ice/ConnectionF.ice +18 -9
- data/slice/Ice/Current.ice +37 -28
- data/slice/Ice/Endpoint.ice +73 -21
- data/slice/Ice/EndpointF.ice +19 -10
- data/slice/Ice/EndpointTypes.ice +21 -13
- data/slice/Ice/FacetMap.ice +19 -10
- data/slice/Ice/Identity.ice +24 -10
- data/slice/Ice/ImplicitContext.ice +41 -33
- data/slice/Ice/ImplicitContextF.ice +17 -9
- data/slice/Ice/Instrumentation.ice +37 -30
- data/slice/Ice/InstrumentationF.ice +19 -10
- data/slice/Ice/LocalException.ice +118 -112
- data/slice/Ice/Locator.ice +28 -21
- data/slice/Ice/LocatorF.ice +18 -9
- data/slice/Ice/Logger.ice +26 -18
- data/slice/Ice/LoggerF.ice +18 -9
- data/slice/Ice/Metrics.ice +42 -30
- data/slice/Ice/ObjectAdapter.ice +88 -53
- data/slice/Ice/ObjectAdapterF.ice +18 -9
- data/slice/Ice/ObjectFactory.ice +28 -17
- data/slice/Ice/Plugin.ice +25 -13
- data/slice/Ice/PluginF.ice +22 -9
- data/slice/Ice/Process.ice +20 -11
- data/slice/Ice/ProcessF.ice +18 -9
- data/slice/Ice/Properties.ice +42 -28
- data/slice/Ice/PropertiesAdmin.ice +20 -10
- data/slice/Ice/PropertiesF.ice +18 -9
- data/slice/Ice/RemoteLogger.ice +23 -19
- data/slice/Ice/Router.ice +28 -13
- data/slice/Ice/RouterF.ice +18 -9
- data/slice/Ice/ServantLocator.ice +40 -29
- data/slice/Ice/ServantLocatorF.ice +18 -9
- data/slice/Ice/SliceChecksumDict.ice +18 -9
- data/slice/Ice/ValueFactory.ice +132 -0
- data/slice/Ice/Version.ice +20 -10
- data/slice/IceBT/ConnectionInfo.ice +58 -0
- data/slice/IceBT/EndpointInfo.ice +56 -0
- data/slice/IceBT/Types.ice +44 -0
- data/slice/IceBox/IceBox.ice +45 -27
- data/slice/IceDiscovery/IceDiscovery.ice +75 -10
- data/slice/IceGrid/Admin.ice +410 -44
- data/slice/IceGrid/Descriptor.ice +47 -34
- data/slice/IceGrid/Exception.ice +43 -32
- data/slice/IceGrid/FileParser.ice +21 -12
- data/slice/IceGrid/PluginFacade.ice +26 -18
- data/slice/IceGrid/Registry.ice +150 -21
- data/slice/IceGrid/Session.ice +25 -17
- data/slice/IceGrid/UserAccountMapper.ice +23 -14
- data/slice/IceIAP/ConnectionInfo.ice +73 -0
- data/slice/IceIAP/EndpointInfo.ice +67 -0
- data/slice/IceLocatorDiscovery/IceLocatorDiscovery.ice +19 -12
- data/slice/IcePatch2/FileInfo.ice +19 -13
- data/slice/IcePatch2/FileServer.ice +27 -18
- data/slice/IceSSL/ConnectionInfo.ice +27 -23
- data/slice/IceSSL/ConnectionInfoF.ice +30 -0
- data/slice/IceSSL/EndpointInfo.ice +21 -36
- data/slice/IceStorm/IceStorm.ice +33 -24
- data/slice/IceStorm/Metrics.ice +19 -11
- metadata +148 -120
- data/ext/ObjectFactory.cpp +0 -140
- data/ext/ObjectFactory.h +0 -50
- data/ext/ice/cpp/include/Ice/ACMF.h +0 -30
- data/ext/ice/cpp/include/Ice/BasicStream.h +0 -1335
- data/ext/ice/cpp/include/Ice/BuiltinSequences.h +0 -82
- data/ext/ice/cpp/include/Ice/Communicator.h +0 -200
- data/ext/ice/cpp/include/Ice/Connection.h +0 -497
- data/ext/ice/cpp/include/Ice/ConnectionF.h +0 -74
- data/ext/ice/cpp/include/Ice/ConnectionFactoryF.h +0 -30
- data/ext/ice/cpp/include/Ice/Current.h +0 -102
- data/ext/ice/cpp/include/Ice/DefaultObjectFactory.h +0 -48
- data/ext/ice/cpp/include/Ice/DeprecatedStringConverter.h +0 -62
- data/ext/ice/cpp/include/Ice/Endpoint.h +0 -341
- data/ext/ice/cpp/include/Ice/EndpointF.h +0 -93
- data/ext/ice/cpp/include/Ice/EndpointTypes.h +0 -82
- data/ext/ice/cpp/include/Ice/Identity.h +0 -168
- data/ext/ice/cpp/include/Ice/ImplicitContext.h +0 -102
- data/ext/ice/cpp/include/Ice/Instrumentation.h +0 -365
- data/ext/ice/cpp/include/Ice/InstrumentationF.h +0 -75
- data/ext/ice/cpp/include/Ice/LocalException.h +0 -1030
- data/ext/ice/cpp/include/Ice/Locator.h +0 -2193
- data/ext/ice/cpp/include/Ice/LocatorF.h +0 -93
- data/ext/ice/cpp/include/Ice/Logger.h +0 -100
- data/ext/ice/cpp/include/Ice/Metrics.h +0 -2974
- data/ext/ice/cpp/include/Ice/ObjectAdapter.h +0 -168
- data/ext/ice/cpp/include/Ice/ObjectAdapterFactoryF.h +0 -26
- data/ext/ice/cpp/include/Ice/ObjectFactory.h +0 -92
- data/ext/ice/cpp/include/Ice/ObjectFactoryF.h +0 -66
- data/ext/ice/cpp/include/Ice/ObjectFactoryManagerF.h +0 -26
- data/ext/ice/cpp/include/Ice/Outgoing.h +0 -225
- data/ext/ice/cpp/include/Ice/Plugin.h +0 -125
- data/ext/ice/cpp/include/Ice/PluginF.h +0 -70
- data/ext/ice/cpp/include/Ice/Process.h +0 -574
- data/ext/ice/cpp/include/Ice/ProcessF.h +0 -83
- data/ext/ice/cpp/include/Ice/Properties.h +0 -136
- data/ext/ice/cpp/include/Ice/PropertiesAdmin.h +0 -830
- data/ext/ice/cpp/include/Ice/PropertiesF.h +0 -87
- data/ext/ice/cpp/include/Ice/RemoteLogger.h +0 -1500
- data/ext/ice/cpp/include/Ice/Router.h +0 -1159
- data/ext/ice/cpp/include/Ice/RouterF.h +0 -83
- data/ext/ice/cpp/include/Ice/ServantLocator.h +0 -96
- data/ext/ice/cpp/include/Ice/Stream.h +0 -447
- data/ext/ice/cpp/include/Ice/StreamF.h +0 -30
- data/ext/ice/cpp/include/Ice/Version.h +0 -262
- data/ext/ice/cpp/include/IceSSL/ConnectionInfo.h +0 -158
- data/ext/ice/cpp/include/IceSSL/EndpointInfo.h +0 -142
- data/ext/ice/cpp/include/IceUtil/AbstractMutex.h +0 -119
- data/ext/ice/cpp/include/IceUtil/Cache.h +0 -362
- data/ext/ice/cpp/include/IceUtil/IconvStringConverter.h +0 -302
- data/ext/ice/cpp/include/IceUtil/SHA1.h +0 -47
- data/ext/ice/cpp/include/Slice/CPlusPlusUtil.h +0 -65
- data/ext/ice/cpp/include/Slice/Checksum.h +0 -26
- data/ext/ice/cpp/include/Slice/CsUtil.h +0 -92
- data/ext/ice/cpp/include/Slice/DotNetNames.h +0 -34
- data/ext/ice/cpp/include/Slice/JavaUtil.h +0 -279
- data/ext/ice/cpp/include/Slice/ObjCUtil.h +0 -127
- data/ext/ice/cpp/include/Slice/PHPUtil.h +0 -50
- data/ext/ice/cpp/include/Slice/PythonUtil.h +0 -64
- data/ext/ice/cpp/include/Slice/Util.h +0 -56
- data/ext/ice/cpp/src/Ice/BasicStream.cpp +0 -3428
- data/ext/ice/cpp/src/Ice/DeprecatedStringConverter.cpp +0 -62
- data/ext/ice/cpp/src/Ice/ObjectFactoryF.cpp +0 -44
- data/ext/ice/cpp/src/Ice/ObjectFactoryManager.cpp +0 -139
- data/ext/ice/cpp/src/Ice/ObjectFactoryManager.h +0 -43
- data/ext/ice/cpp/src/Ice/Outgoing.cpp +0 -694
- data/ext/ice/cpp/src/Ice/Stream.cpp +0 -53
- data/ext/ice/cpp/src/Ice/StreamI.cpp +0 -832
- data/ext/ice/cpp/src/Ice/StreamI.h +0 -198
- data/ext/ice/cpp/src/IceSSL/Certificate.cpp +0 -1336
- data/ext/ice/cpp/src/IceUtil/ArgVector.cpp +0 -64
- data/ext/ice/cpp/src/IceUtil/ArgVector.h +0 -41
- data/ext/ice/cpp/src/IceUtil/Exception.cpp +0 -792
- data/ext/ice/cpp/src/IceUtil/FileUtil.h +0 -185
- data/ext/ice/cpp/src/Slice/CsUtil.cpp +0 -2660
- data/ext/ice/cpp/src/Slice/DotNetNames.cpp +0 -146
- data/ext/ice/cpp/src/Slice/ObjCUtil.cpp +0 -1310
- data/lib/Ice/ObjectFactoryF.rb +0 -29
- data/lib/IceGrid/Locator.rb +0 -106
- data/lib/IceGrid/Observer.rb +0 -572
- data/lib/IceGrid/Query.rb +0 -169
- data/slice/Freeze/BackgroundSaveEvictor.ice +0 -111
- data/slice/Freeze/CatalogData.ice +0 -49
- data/slice/Freeze/Connection.ice +0 -121
- data/slice/Freeze/ConnectionF.ice +0 -20
- data/slice/Freeze/DB.ice +0 -37
- data/slice/Freeze/Evictor.ice +0 -346
- data/slice/Freeze/EvictorF.ice +0 -22
- data/slice/Freeze/EvictorStorage.ice +0 -72
- data/slice/Freeze/Exception.ice +0 -100
- data/slice/Freeze/Transaction.ice +0 -58
- data/slice/Freeze/TransactionalEvictor.ice +0 -50
- data/slice/Ice/ObjectFactoryF.ice +0 -21
- data/slice/IceGrid/Locator.ice +0 -57
- data/slice/IceGrid/Observer.ice +0 -395
- data/slice/IceGrid/Query.ice +0 -131
@@ -0,0 +1,70 @@
|
|
1
|
+
//
|
2
|
+
// Copyright (c) ZeroC, Inc. All rights reserved.
|
3
|
+
//
|
4
|
+
|
5
|
+
#ifndef SLICE_PYTHON_UTIL_H
|
6
|
+
#define SLICE_PYTHON_UTIL_H
|
7
|
+
|
8
|
+
#include <Slice/Parser.h>
|
9
|
+
#include <IceUtil/OutputUtil.h>
|
10
|
+
|
11
|
+
namespace Slice
|
12
|
+
{
|
13
|
+
namespace Python
|
14
|
+
{
|
15
|
+
|
16
|
+
//
|
17
|
+
// Get the package directory from metadata (if any).
|
18
|
+
//
|
19
|
+
std::string getPackageDirectory(const std::string&, const Slice::UnitPtr&);
|
20
|
+
|
21
|
+
//
|
22
|
+
// Determine the name of a Python source file for use in an import statement.
|
23
|
+
// The return value does not include the .py extension.
|
24
|
+
//
|
25
|
+
std::string getImportFileName(const std::string&, const Slice::UnitPtr&, const std::vector<std::string>&);
|
26
|
+
|
27
|
+
//
|
28
|
+
// Generate Python code for a translation unit.
|
29
|
+
//
|
30
|
+
void generate(const Slice::UnitPtr&, bool, bool, const std::vector<std::string>&, IceUtilInternal::Output&);
|
31
|
+
|
32
|
+
//
|
33
|
+
// Convert a scoped name into a Python name.
|
34
|
+
//
|
35
|
+
std::string scopedToName(const std::string&);
|
36
|
+
|
37
|
+
//
|
38
|
+
// Check the given identifier against Python's list of reserved words. If it matches
|
39
|
+
// a reserved word, then an escaped version is returned with a leading underscore.
|
40
|
+
//
|
41
|
+
std::string fixIdent(const std::string&);
|
42
|
+
|
43
|
+
//
|
44
|
+
// Return the package specified by metadata for the given definition,
|
45
|
+
// or an empty string if no metadata was found.
|
46
|
+
//
|
47
|
+
std::string getPackageMetadata(const Slice::ContainedPtr&);
|
48
|
+
|
49
|
+
//
|
50
|
+
// Get the fully-qualified name of the given definition, including any
|
51
|
+
// package defined via metadata. If a suffix is provided, it is
|
52
|
+
// prepended to the definition's unqualified name. If the nameSuffix
|
53
|
+
// is provided, it is appended to the containers name.
|
54
|
+
//
|
55
|
+
// COMPILERFIX: MSVC 6 seems to have a problem with const std::string
|
56
|
+
// = std::string(), const std::string = std::string().
|
57
|
+
//
|
58
|
+
std::string getAbsolute(const Slice::ContainedPtr&, const std::string& = "", const std::string& = "");
|
59
|
+
|
60
|
+
//
|
61
|
+
// Emit a comment header.
|
62
|
+
//
|
63
|
+
void printHeader(IceUtilInternal::Output&);
|
64
|
+
|
65
|
+
int compile(const std::vector<std::string>&);
|
66
|
+
|
67
|
+
}
|
68
|
+
}
|
69
|
+
|
70
|
+
#endif
|
@@ -1,17 +1,13 @@
|
|
1
|
-
// **********************************************************************
|
2
1
|
//
|
3
|
-
// Copyright (c)
|
2
|
+
// Copyright (c) ZeroC, Inc. All rights reserved.
|
4
3
|
//
|
5
|
-
// This copy of Ice is licensed to you under the terms described in the
|
6
|
-
// ICE_LICENSE file included in this distribution.
|
7
|
-
//
|
8
|
-
// **********************************************************************
|
9
4
|
|
10
|
-
#include <IceUtil/
|
5
|
+
#include <IceUtil/StringUtil.h>
|
11
6
|
#include <IceUtil/Options.h>
|
12
7
|
#include <IceUtil/CtrlCHandler.h>
|
13
8
|
#include <IceUtil/Mutex.h>
|
14
9
|
#include <IceUtil/MutexPtrLock.h>
|
10
|
+
#include <IceUtil/ConsoleUtil.h>
|
15
11
|
#include <Slice/Preprocessor.h>
|
16
12
|
#include <Slice/FileTracker.h>
|
17
13
|
#include <Slice/RubyUtil.h>
|
@@ -22,6 +18,7 @@
|
|
22
18
|
using namespace std;
|
23
19
|
using namespace Slice;
|
24
20
|
using namespace Slice::Ruby;
|
21
|
+
using namespace IceUtilInternal;
|
25
22
|
|
26
23
|
namespace
|
27
24
|
{
|
@@ -58,25 +55,27 @@ interruptedCallback(int /*signal*/)
|
|
58
55
|
void
|
59
56
|
usage(const string& n)
|
60
57
|
{
|
61
|
-
|
62
|
-
|
58
|
+
consoleErr << "Usage: " << n << " [options] slice-files...\n";
|
59
|
+
consoleErr <<
|
63
60
|
"Options:\n"
|
64
|
-
"-h, --help
|
65
|
-
"-v, --version
|
66
|
-
"-DNAME
|
67
|
-
"-DNAME=DEF
|
68
|
-
"-UNAME
|
69
|
-
"-IDIR
|
70
|
-
"-E
|
71
|
-
"--output-dir DIR
|
72
|
-
"--
|
73
|
-
"--depend
|
74
|
-
"--depend-
|
75
|
-
"-
|
76
|
-
"--
|
77
|
-
"--
|
78
|
-
"--
|
79
|
-
"
|
61
|
+
"-h, --help Show this message.\n"
|
62
|
+
"-v, --version Display the Ice version.\n"
|
63
|
+
"-DNAME Define NAME as 1.\n"
|
64
|
+
"-DNAME=DEF Define NAME as DEF.\n"
|
65
|
+
"-UNAME Remove any definition for NAME.\n"
|
66
|
+
"-IDIR Put DIR in the include file search path.\n"
|
67
|
+
"-E Print preprocessor output on stdout.\n"
|
68
|
+
"--output-dir DIR Create files in the directory DIR.\n"
|
69
|
+
"-d, --debug Print debug messages.\n"
|
70
|
+
"--depend Generate Makefile dependencies.\n"
|
71
|
+
"--depend-xml Generate dependencies in XML format.\n"
|
72
|
+
"--depend-file FILE Write dependencies to FILE instead of standard output.\n"
|
73
|
+
"--all Generate code for Slice definitions in included files.\n"
|
74
|
+
"--checksum Generate checksums for Slice definitions.\n"
|
75
|
+
"--ice Allow reserved Ice prefix in Slice identifiers\n"
|
76
|
+
" deprecated: use instead [[\"ice-prefix\"]] metadata.\n"
|
77
|
+
"--underscore Allow underscores in Slice identifiers\n"
|
78
|
+
" deprecated: use instead [[\"underscore\"]] metadata.\n"
|
80
79
|
;
|
81
80
|
}
|
82
81
|
|
@@ -109,7 +108,7 @@ Slice::Ruby::compile(const vector
|
|
109
108
|
}
|
110
109
|
catch(const IceUtilInternal::BadOptException& e)
|
111
110
|
{
|
112
|
-
|
111
|
+
consoleErr << argv[0] << ": error: " << e.reason << endl;
|
113
112
|
usage(argv[0]);
|
114
113
|
return EXIT_FAILURE;
|
115
114
|
}
|
@@ -122,7 +121,7 @@ Slice::Ruby::compile(const vector
|
|
122
121
|
|
123
122
|
if(opts.isSet("version"))
|
124
123
|
{
|
125
|
-
|
124
|
+
consoleErr << ICE_STRING_VERSION << endl;
|
126
125
|
return EXIT_SUCCESS;
|
127
126
|
}
|
128
127
|
|
@@ -167,14 +166,14 @@ Slice::Ruby::compile(const vector
|
|
167
166
|
|
168
167
|
if(args.empty())
|
169
168
|
{
|
170
|
-
|
169
|
+
consoleErr << argv[0] << ": error: no input file" << endl;
|
171
170
|
usage(argv[0]);
|
172
171
|
return EXIT_FAILURE;
|
173
172
|
}
|
174
173
|
|
175
174
|
if(depend && dependxml)
|
176
175
|
{
|
177
|
-
|
176
|
+
consoleErr << argv[0] << ": error: cannot specify both --depend and --dependxml" << endl;
|
178
177
|
usage(argv[0]);
|
179
178
|
return EXIT_FAILURE;
|
180
179
|
}
|
@@ -184,10 +183,10 @@ Slice::Ruby::compile(const vector
|
|
184
183
|
IceUtil::CtrlCHandler ctrlCHandler;
|
185
184
|
ctrlCHandler.setCallback(interruptedCallback);
|
186
185
|
|
187
|
-
|
186
|
+
ostringstream os;
|
188
187
|
if(dependxml)
|
189
188
|
{
|
190
|
-
|
189
|
+
os << "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<dependencies>" << endl;
|
191
190
|
}
|
192
191
|
|
193
192
|
for(vector<string>::const_iterator i = args.begin(); i != args.end(); ++i)
|
@@ -208,7 +207,6 @@ Slice::Ruby::compile(const vector
|
|
208
207
|
|
209
208
|
if(cppHandle == 0)
|
210
209
|
{
|
211
|
-
out.cleanup();
|
212
210
|
return EXIT_FAILURE;
|
213
211
|
}
|
214
212
|
|
@@ -218,20 +216,17 @@ Slice::Ruby::compile(const vector
|
|
218
216
|
|
219
217
|
if(parseStatus == EXIT_FAILURE)
|
220
218
|
{
|
221
|
-
out.cleanup();
|
222
219
|
return EXIT_FAILURE;
|
223
220
|
}
|
224
221
|
|
225
|
-
if(!icecpp->printMakefileDependencies(
|
222
|
+
if(!icecpp->printMakefileDependencies(os, depend ? Preprocessor::Ruby : Preprocessor::SliceXML, includePaths,
|
226
223
|
"-D__SLICE2RB__"))
|
227
224
|
{
|
228
|
-
out.cleanup();
|
229
225
|
return EXIT_FAILURE;
|
230
226
|
}
|
231
227
|
|
232
228
|
if(!icecpp->close())
|
233
229
|
{
|
234
|
-
out.cleanup();
|
235
230
|
return EXIT_FAILURE;
|
236
231
|
}
|
237
232
|
}
|
@@ -248,7 +243,7 @@ Slice::Ruby::compile(const vector
|
|
248
243
|
if(preprocess)
|
249
244
|
{
|
250
245
|
char buf[4096];
|
251
|
-
while(fgets(buf, static_cast<int>(sizeof(buf)), cppHandle) !=
|
246
|
+
while(fgets(buf, static_cast<int>(sizeof(buf)), cppHandle) != ICE_NULLPTR)
|
252
247
|
{
|
253
248
|
if(fputs(buf, stdout) == EOF)
|
254
249
|
{
|
@@ -296,9 +291,9 @@ Slice::Ruby::compile(const vector
|
|
296
291
|
out.open(file.c_str());
|
297
292
|
if(!out)
|
298
293
|
{
|
299
|
-
ostringstream
|
300
|
-
|
301
|
-
throw FileException(__FILE__, __LINE__,
|
294
|
+
ostringstream oss;
|
295
|
+
oss << "cannot open`" << file << "': " << IceUtilInternal::errorToString(errno);
|
296
|
+
throw FileException(__FILE__, __LINE__, oss.str());
|
302
297
|
}
|
303
298
|
FileTracker::instance()->addFile(file);
|
304
299
|
//
|
@@ -321,7 +316,7 @@ Slice::Ruby::compile(const vector
|
|
321
316
|
// any created files.
|
322
317
|
FileTracker::instance()->cleanup();
|
323
318
|
u->destroy();
|
324
|
-
|
319
|
+
consoleErr << argv[0] << ": error: " << ex.reason() << endl;
|
325
320
|
return EXIT_FAILURE;
|
326
321
|
}
|
327
322
|
}
|
@@ -335,7 +330,6 @@ Slice::Ruby::compile(const vector
|
|
335
330
|
|
336
331
|
if(interrupted)
|
337
332
|
{
|
338
|
-
out.cleanup();
|
339
333
|
FileTracker::instance()->cleanup();
|
340
334
|
return EXIT_FAILURE;
|
341
335
|
}
|
@@ -344,7 +338,12 @@ Slice::Ruby::compile(const vector
|
|
344
338
|
|
345
339
|
if(dependxml)
|
346
340
|
{
|
347
|
-
|
341
|
+
os << "</dependencies>\n";
|
342
|
+
}
|
343
|
+
|
344
|
+
if(depend || dependxml)
|
345
|
+
{
|
346
|
+
writeDependencies(os.str(), dependFile);
|
348
347
|
}
|
349
348
|
|
350
349
|
return status;
|
@@ -1,18 +1,12 @@
|
|
1
|
-
// **********************************************************************
|
2
1
|
//
|
3
|
-
// Copyright (c)
|
2
|
+
// Copyright (c) ZeroC, Inc. All rights reserved.
|
4
3
|
//
|
5
|
-
// This copy of Ice is licensed to you under the terms described in the
|
6
|
-
// ICE_LICENSE file included in this distribution.
|
7
|
-
//
|
8
|
-
// **********************************************************************
|
9
4
|
|
10
5
|
#include <Slice/RubyUtil.h>
|
11
6
|
#include <Slice/Checksum.h>
|
12
7
|
#include <Slice/Util.h>
|
13
8
|
#include <IceUtil/Functional.h>
|
14
9
|
#include <IceUtil/InputUtil.h>
|
15
|
-
#include <IceUtil/Unicode.h>
|
16
10
|
#include <iterator>
|
17
11
|
|
18
12
|
using namespace std;
|
@@ -20,6 +14,26 @@ using namespace Slice;
|
|
20
14
|
using namespace IceUtil;
|
21
15
|
using namespace IceUtilInternal;
|
22
16
|
|
17
|
+
namespace
|
18
|
+
{
|
19
|
+
|
20
|
+
string
|
21
|
+
getEscapedParamName(const OperationPtr& p, const string& name)
|
22
|
+
{
|
23
|
+
ParamDeclList params = p->parameters();
|
24
|
+
|
25
|
+
for(ParamDeclList::const_iterator i = params.begin(); i != params.end(); ++i)
|
26
|
+
{
|
27
|
+
if((*i)->name() == name)
|
28
|
+
{
|
29
|
+
return name + "_";
|
30
|
+
}
|
31
|
+
}
|
32
|
+
return name;
|
33
|
+
}
|
34
|
+
|
35
|
+
}
|
36
|
+
|
23
37
|
namespace Slice
|
24
38
|
{
|
25
39
|
namespace Ruby
|
@@ -48,12 +62,12 @@ public:
|
|
48
62
|
private:
|
49
63
|
|
50
64
|
//
|
51
|
-
// Return a
|
65
|
+
// Return a Ruby symbol for the given parser element.
|
52
66
|
//
|
53
67
|
string getSymbol(const ContainedPtr&);
|
54
68
|
|
55
69
|
//
|
56
|
-
// Emit
|
70
|
+
// Emit Ruby code to assign the given symbol in the current module.
|
57
71
|
//
|
58
72
|
void registerName(const string&);
|
59
73
|
|
@@ -223,225 +237,53 @@ Slice::Ruby::CodeVisitor::visitClassDecl(const ClassDeclPtr& p)
|
|
223
237
|
bool
|
224
238
|
Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
225
239
|
{
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
ClassDefPtr base;
|
230
|
-
OperationList ops = p->operations();
|
240
|
+
bool isInterface = p->isInterface();
|
241
|
+
bool isLocal = p->isLocal();
|
242
|
+
bool isAbstract = isInterface || p->allOperations().size() > 0; // Don't use isAbstract() - see bug 3739
|
231
243
|
|
232
244
|
//
|
233
|
-
//
|
245
|
+
// Do not generate any code for local interfaces.
|
234
246
|
//
|
235
|
-
|
236
|
-
_out.inc();
|
237
|
-
_out << nl << "module " << name << "_mixin";
|
238
|
-
_out.inc();
|
239
|
-
|
240
|
-
if(!p->isLocal())
|
247
|
+
if(isLocal && isInterface)
|
241
248
|
{
|
242
|
-
|
243
|
-
{
|
244
|
-
base = bases.front();
|
245
|
-
_out << nl << "include " << getAbsolute(bases.front(), IdentToUpper) << "_mixin";
|
246
|
-
}
|
247
|
-
else
|
248
|
-
{
|
249
|
-
_out << nl << "include ::Ice::Object_mixin";
|
250
|
-
}
|
251
|
-
|
252
|
-
//
|
253
|
-
// ice_ids
|
254
|
-
//
|
255
|
-
ClassList allBases = p->allBases();
|
256
|
-
StringList ids;
|
257
|
-
transform(allBases.begin(), allBases.end(), back_inserter(ids), IceUtil::constMemFun(&Contained::scoped));
|
258
|
-
StringList other;
|
259
|
-
other.push_back(scoped);
|
260
|
-
other.push_back("::Ice::Object");
|
261
|
-
other.sort();
|
262
|
-
ids.merge(other);
|
263
|
-
ids.unique();
|
264
|
-
_out << sp << nl << "def ice_ids(current=nil)";
|
265
|
-
_out.inc();
|
266
|
-
_out << nl << "[";
|
267
|
-
for(StringList::iterator q = ids.begin(); q != ids.end(); ++q)
|
268
|
-
{
|
269
|
-
if(q != ids.begin())
|
270
|
-
{
|
271
|
-
_out << ", ";
|
272
|
-
}
|
273
|
-
_out << "'" << *q << "'";
|
274
|
-
}
|
275
|
-
_out << ']';
|
276
|
-
_out.dec();
|
277
|
-
_out << nl << "end";
|
278
|
-
|
279
|
-
//
|
280
|
-
// ice_id
|
281
|
-
//
|
282
|
-
_out << sp << nl << "def ice_id(current=nil)";
|
283
|
-
_out.inc();
|
284
|
-
_out << nl << "'" << scoped << "'";
|
285
|
-
_out.dec();
|
286
|
-
_out << nl << "end";
|
249
|
+
return false;
|
287
250
|
}
|
288
251
|
|
289
|
-
if(
|
290
|
-
|
291
|
-
//
|
292
|
-
// Emit a comment for each operation.
|
293
|
-
//
|
294
|
-
_out << sp
|
295
|
-
<< nl << "#"
|
296
|
-
<< nl << "# Operation signatures."
|
297
|
-
<< nl << "#";
|
298
|
-
for(OperationList::iterator oli = ops.begin(); oli != ops.end(); ++oli)
|
299
|
-
{
|
300
|
-
string fixedOpName = fixIdent((*oli)->name(), IdentNormal);
|
301
|
-
/* If AMI/AMD is ever implemented...
|
302
|
-
if(!p->isLocal() && (p->hasMetaData("amd") || (*oli)->hasMetaData("amd")))
|
303
|
-
{
|
304
|
-
_out << nl << "# def " << fixedOpName << "_async(_cb";
|
305
|
-
|
306
|
-
ParamDeclList params = (*oli)->parameters();
|
307
|
-
|
308
|
-
for(ParamDeclList::iterator pli = params.begin(); pli != params.end(); ++pli)
|
309
|
-
{
|
310
|
-
if(!(*pli)->isOutParam())
|
311
|
-
{
|
312
|
-
_out << ", " << fixIdent((*pli)->name(), IdentToLower);
|
313
|
-
}
|
314
|
-
}
|
315
|
-
if(!p->isLocal())
|
316
|
-
{
|
317
|
-
_out << ", current=nil";
|
318
|
-
}
|
319
|
-
_out << ")";
|
320
|
-
}
|
321
|
-
else
|
322
|
-
*/
|
323
|
-
{
|
324
|
-
_out << nl << "# def " << fixedOpName << "(";
|
325
|
-
|
326
|
-
ParamDeclList params = (*oli)->parameters();
|
327
|
-
|
328
|
-
bool first = true;
|
329
|
-
for(ParamDeclList::iterator pli = params.begin(); pli != params.end(); ++pli)
|
330
|
-
{
|
331
|
-
if(!(*pli)->isOutParam())
|
332
|
-
{
|
333
|
-
if(first)
|
334
|
-
{
|
335
|
-
first = false;
|
336
|
-
}
|
337
|
-
else
|
338
|
-
{
|
339
|
-
_out << ", ";
|
340
|
-
}
|
341
|
-
_out << fixIdent((*pli)->name(), IdentToLower);
|
342
|
-
}
|
343
|
-
}
|
344
|
-
if(!p->isLocal())
|
345
|
-
{
|
346
|
-
if(!first)
|
347
|
-
{
|
348
|
-
_out << ", ";
|
349
|
-
}
|
350
|
-
_out << "current=nil";
|
351
|
-
}
|
352
|
-
_out << ")";
|
353
|
-
}
|
354
|
-
}
|
355
|
-
}
|
252
|
+
_out << sp << nl << "if not defined?(" << getAbsolute(p, IdentToUpper) << "_Mixin)";
|
253
|
+
_out.inc();
|
356
254
|
|
357
255
|
//
|
358
|
-
//
|
256
|
+
// Marker to avoid redefinitions, we don't use the actual class names at those might
|
257
|
+
// be defined by IceRuby for some internal classes
|
359
258
|
//
|
360
|
-
_out << sp << nl << "
|
361
|
-
_out.inc();
|
362
|
-
_out << nl << "::Ice::__stringify(self, T_" << name << ")";
|
363
|
-
_out.dec();
|
259
|
+
_out << sp << nl << "module " << getAbsolute(p, IdentToUpper) << "_Mixin";
|
364
260
|
_out << nl << "end";
|
365
261
|
|
366
|
-
|
367
|
-
|
368
|
-
|
369
|
-
|
370
|
-
|
371
|
-
{
|
372
|
-
bool prot = p->hasMetaData("protected");
|
373
|
-
DataMemberList protectedMembers;
|
262
|
+
string scoped = p->scoped();
|
263
|
+
string name = fixIdent(p->name(), IdentToUpper);
|
264
|
+
ClassList bases = p->bases();
|
265
|
+
ClassDefPtr base;
|
266
|
+
OperationList ops = p->operations();
|
374
267
|
|
375
|
-
|
376
|
-
for(DataMemberList::iterator q = members.begin(); q != members.end(); ++q)
|
377
|
-
{
|
378
|
-
if(q != members.begin())
|
379
|
-
{
|
380
|
-
_out << ", ";
|
381
|
-
}
|
382
|
-
_out << ":" << fixIdent((*q)->name(), IdentNormal);
|
383
|
-
if(prot || (*q)->hasMetaData("protected"))
|
384
|
-
{
|
385
|
-
protectedMembers.push_back(*q);
|
386
|
-
}
|
387
|
-
}
|
268
|
+
DataMemberList members = p->dataMembers();
|
388
269
|
|
389
|
-
|
270
|
+
if(isLocal || !isInterface)
|
271
|
+
{
|
272
|
+
if(!bases.empty() && !bases.front()->isInterface())
|
390
273
|
{
|
391
|
-
|
392
|
-
for(DataMemberList::iterator q = protectedMembers.begin(); q != protectedMembers.end(); ++q)
|
393
|
-
{
|
394
|
-
if(q != protectedMembers.begin())
|
395
|
-
{
|
396
|
-
_out << ", ";
|
397
|
-
}
|
398
|
-
//
|
399
|
-
// We need to list the symbols of the reader and the writer (e.g., ":member" and ":member=").
|
400
|
-
//
|
401
|
-
_out << ":" << fixIdent((*q)->name(), IdentNormal) << ", :"
|
402
|
-
<< fixIdent((*q)->name(), IdentNormal) << '=';
|
403
|
-
}
|
274
|
+
base = bases.front();
|
404
275
|
}
|
405
|
-
}
|
406
276
|
|
407
|
-
_out.dec();
|
408
|
-
_out << nl << "end"; // End of mix-in module for class.
|
409
|
-
|
410
|
-
if(p->isInterface())
|
411
|
-
{
|
412
|
-
//
|
413
|
-
// Class.
|
414
|
-
//
|
415
|
-
_out << nl << "class " << name;
|
416
|
-
_out.inc();
|
417
|
-
_out << nl << "include " << name << "_mixin";
|
418
|
-
_out << nl;
|
419
|
-
_out << nl << "def " << name << ".ice_staticId()";
|
420
|
-
_out.inc();
|
421
|
-
_out << nl << "'" << scoped << "'";
|
422
|
-
_out.dec();
|
423
|
-
_out << nl << "end";
|
424
|
-
_out.dec();
|
425
|
-
_out << nl << "end";
|
426
|
-
}
|
427
|
-
else
|
428
|
-
{
|
429
|
-
//
|
430
|
-
// Class.
|
431
|
-
//
|
432
277
|
_out << nl << "class " << name;
|
433
278
|
if(base)
|
434
279
|
{
|
435
280
|
_out << " < " << getAbsolute(base, IdentToUpper);
|
436
281
|
}
|
282
|
+
else if(!isLocal)
|
283
|
+
{
|
284
|
+
_out << " < ::Ice::Value";
|
285
|
+
}
|
437
286
|
_out.inc();
|
438
|
-
_out << nl << "include " << name << "_mixin";
|
439
|
-
_out << nl;
|
440
|
-
_out << nl << "def " << name << ".ice_staticId()";
|
441
|
-
_out.inc();
|
442
|
-
_out << nl << "'" << scoped << "'";
|
443
|
-
_out.dec();
|
444
|
-
_out << nl << "end";
|
445
287
|
|
446
288
|
//
|
447
289
|
// initialize
|
@@ -490,6 +332,46 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
490
332
|
_out << nl << "end";
|
491
333
|
}
|
492
334
|
|
335
|
+
//
|
336
|
+
// read/write accessors for data members.
|
337
|
+
//
|
338
|
+
if(!members.empty())
|
339
|
+
{
|
340
|
+
bool prot = p->hasMetaData("protected");
|
341
|
+
DataMemberList protectedMembers;
|
342
|
+
|
343
|
+
_out << sp << nl << "attr_accessor ";
|
344
|
+
for(DataMemberList::iterator q = members.begin(); q != members.end(); ++q)
|
345
|
+
{
|
346
|
+
if(q != members.begin())
|
347
|
+
{
|
348
|
+
_out << ", ";
|
349
|
+
}
|
350
|
+
_out << ":" << fixIdent((*q)->name(), IdentNormal);
|
351
|
+
if(prot || (*q)->hasMetaData("protected"))
|
352
|
+
{
|
353
|
+
protectedMembers.push_back(*q);
|
354
|
+
}
|
355
|
+
}
|
356
|
+
|
357
|
+
if(!protectedMembers.empty())
|
358
|
+
{
|
359
|
+
_out << nl << "protected ";
|
360
|
+
for(DataMemberList::iterator q = protectedMembers.begin(); q != protectedMembers.end(); ++q)
|
361
|
+
{
|
362
|
+
if(q != protectedMembers.begin())
|
363
|
+
{
|
364
|
+
_out << ", ";
|
365
|
+
}
|
366
|
+
//
|
367
|
+
// We need to list the symbols of the reader and the writer (e.g., ":member" and ":member=").
|
368
|
+
//
|
369
|
+
_out << ":" << fixIdent((*q)->name(), IdentNormal) << ", :"
|
370
|
+
<< fixIdent((*q)->name(), IdentNormal) << '=';
|
371
|
+
}
|
372
|
+
}
|
373
|
+
}
|
374
|
+
|
493
375
|
_out.dec();
|
494
376
|
_out << nl << "end"; // End of class.
|
495
377
|
}
|
@@ -498,13 +380,17 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
498
380
|
// Generate proxy support. This includes a mix-in module for the proxy's
|
499
381
|
// operations and a class for the proxy itself.
|
500
382
|
//
|
501
|
-
if(!p->isLocal())
|
383
|
+
if(!p->isLocal() && isAbstract)
|
502
384
|
{
|
503
385
|
_out << nl << "module " << name << "Prx_mixin";
|
504
386
|
_out.inc();
|
505
387
|
for(ClassList::iterator cli = bases.begin(); cli != bases.end(); ++cli)
|
506
388
|
{
|
507
|
-
|
389
|
+
ClassDefPtr def = *cli;
|
390
|
+
if(def->isInterface() || def->allOperations().size() > 0)
|
391
|
+
{
|
392
|
+
_out << nl << "include " << getAbsolute(*cli, IdentToUpper) << "Prx_mixin";
|
393
|
+
}
|
508
394
|
}
|
509
395
|
for(OperationList::iterator oli = ops.begin(); oli != ops.end(); ++oli)
|
510
396
|
{
|
@@ -534,38 +420,21 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
534
420
|
{
|
535
421
|
_out << inParams << ", ";
|
536
422
|
}
|
537
|
-
|
423
|
+
const string contextParamName = getEscapedParamName(*oli, "context");
|
424
|
+
_out << contextParamName << "=nil)";
|
538
425
|
_out.inc();
|
539
|
-
_out << nl << name << "
|
540
|
-
_out << "],
|
426
|
+
_out << nl << name << "Prx_mixin::OP_" << (*oli)->name() << ".invoke(self, [" << inParams;
|
427
|
+
_out << "], " << contextParamName << ")";
|
541
428
|
_out.dec();
|
542
429
|
_out << nl << "end";
|
543
430
|
}
|
544
431
|
_out.dec();
|
545
432
|
_out << nl << "end"; // End of mix-in module for proxy.
|
546
433
|
|
547
|
-
_out << nl << "class " << name << "Prx < ::Ice::ObjectPrx";
|
434
|
+
_out << sp << nl << "class " << name << "Prx < ::Ice::ObjectPrx";
|
548
435
|
_out.inc();
|
436
|
+
_out << nl << "include ::Ice::Proxy_mixin";
|
549
437
|
_out << nl << "include " << name << "Prx_mixin";
|
550
|
-
|
551
|
-
_out << sp << nl << "def " << name << "Prx.checkedCast(proxy, facetOrCtx=nil, _ctx=nil)";
|
552
|
-
_out.inc();
|
553
|
-
_out << nl << "ice_checkedCast(proxy, '" << scoped << "', facetOrCtx, _ctx)";
|
554
|
-
_out.dec();
|
555
|
-
_out << nl << "end";
|
556
|
-
|
557
|
-
_out << sp << nl << "def " << name << "Prx.uncheckedCast(proxy, facet=nil)";
|
558
|
-
_out.inc();
|
559
|
-
_out << nl << "ice_uncheckedCast(proxy, facet)";
|
560
|
-
_out.dec();
|
561
|
-
_out << nl << "end";
|
562
|
-
|
563
|
-
_out << nl << "def " << name << "Prx.ice_staticId()";
|
564
|
-
_out.inc();
|
565
|
-
_out << nl << "'" << scoped << "'";
|
566
|
-
_out.dec();
|
567
|
-
_out << nl << "end";
|
568
|
-
|
569
438
|
_out.dec();
|
570
439
|
_out << nl << "end"; // End of proxy class.
|
571
440
|
}
|
@@ -573,7 +442,12 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
573
442
|
//
|
574
443
|
// Emit type descriptions.
|
575
444
|
//
|
576
|
-
_out << sp << nl << "if not defined?(" << getAbsolute(p, IdentToUpper, "T_")
|
445
|
+
_out << sp << nl << "if not defined?(" << getAbsolute(p, IdentToUpper, "T_");
|
446
|
+
if(isInterface)
|
447
|
+
{
|
448
|
+
_out << "Prx";
|
449
|
+
}
|
450
|
+
_out << ')';
|
577
451
|
_out.inc();
|
578
452
|
if(p->isLocal())
|
579
453
|
{
|
@@ -582,16 +456,22 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
582
456
|
else
|
583
457
|
{
|
584
458
|
_out << nl << "T_" << name << " = ::Ice::__declareClass('" << scoped << "')";
|
585
|
-
|
459
|
+
if(isAbstract)
|
460
|
+
{
|
461
|
+
_out << nl << "T_" << name << "Prx = ::Ice::__declareProxy('" << scoped << "')";
|
462
|
+
}
|
586
463
|
}
|
587
464
|
_out.dec();
|
588
465
|
_out << nl << "end";
|
589
466
|
_classHistory.insert(scoped); // Avoid redundant declarations.
|
590
467
|
|
591
|
-
bool isAbstract = p->isInterface() || p->allOperations().size() > 0; // Don't use isAbstract() here - see bug 3739
|
592
468
|
const bool preserved = p->hasMetaData("preserve-slice") || p->inheritsMetaData("preserve-slice");
|
593
|
-
|
594
|
-
|
469
|
+
|
470
|
+
_out << sp << nl << "T_" << name << ".defineClass("
|
471
|
+
<< (isInterface ? "::Ice::Value" : name) << ", "
|
472
|
+
<< p->compactId() << ", "
|
473
|
+
<< (preserved ? "true" : "false") << ", "
|
474
|
+
<< (isInterface ? "true" : "false") << ", ";
|
595
475
|
if(!base)
|
596
476
|
{
|
597
477
|
_out << "nil";
|
@@ -600,25 +480,7 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
600
480
|
{
|
601
481
|
_out << getAbsolute(base, IdentToUpper, "T_");
|
602
482
|
}
|
603
|
-
_out << ",
|
604
|
-
//
|
605
|
-
// Interfaces
|
606
|
-
//
|
607
|
-
{
|
608
|
-
int interfaceCount = 0;
|
609
|
-
for(ClassList::const_iterator q = bases.begin(); q != bases.end(); ++q)
|
610
|
-
{
|
611
|
-
if((*q)->isInterface())
|
612
|
-
{
|
613
|
-
if(interfaceCount > 0)
|
614
|
-
{
|
615
|
-
_out << ", ";
|
616
|
-
}
|
617
|
-
_out << getAbsolute(*q, IdentToUpper, "T_");
|
618
|
-
++interfaceCount;
|
619
|
-
}
|
620
|
-
}
|
621
|
-
}
|
483
|
+
_out << ", ";
|
622
484
|
//
|
623
485
|
// Members
|
624
486
|
//
|
@@ -628,7 +490,7 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
628
490
|
//
|
629
491
|
// where MemberType is either a primitive type constant (T_INT, etc.) or the id of a constructed type.
|
630
492
|
//
|
631
|
-
_out << "
|
493
|
+
_out << "[";
|
632
494
|
if(members.size() > 1)
|
633
495
|
{
|
634
496
|
_out.inc();
|
@@ -653,7 +515,6 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
653
515
|
_out << nl;
|
654
516
|
}
|
655
517
|
_out << "])";
|
656
|
-
_out << nl << name << "_mixin::ICE_TYPE = T_" << name;
|
657
518
|
|
658
519
|
//
|
659
520
|
// Define each operation. The arguments to __defineOperation are:
|
@@ -663,10 +524,39 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
663
524
|
// where InParams and OutParams are arrays of type descriptions, and Exceptions
|
664
525
|
// is an array of exception types.
|
665
526
|
//
|
666
|
-
if(!p->isLocal())
|
527
|
+
if(!p->isLocal() && isAbstract)
|
667
528
|
{
|
668
|
-
_out << sp << nl << "T_" << name << "Prx.defineProxy(" << name << "Prx,
|
669
|
-
|
529
|
+
_out << sp << nl << "T_" << name << "Prx.defineProxy(" << name << "Prx, ";
|
530
|
+
|
531
|
+
if(!base || (!base->isInterface() && base->allOperations().size() == 0))
|
532
|
+
{
|
533
|
+
_out << "nil";
|
534
|
+
}
|
535
|
+
else
|
536
|
+
{
|
537
|
+
_out << getAbsolute(base, IdentToUpper, "T_") << "Prx";
|
538
|
+
}
|
539
|
+
|
540
|
+
//
|
541
|
+
// Interfaces
|
542
|
+
//
|
543
|
+
_out << ", [";
|
544
|
+
{
|
545
|
+
int interfaceCount = 0;
|
546
|
+
for(ClassList::const_iterator q = bases.begin(); q != bases.end(); ++q)
|
547
|
+
{
|
548
|
+
if((*q)->isInterface())
|
549
|
+
{
|
550
|
+
if(interfaceCount > 0)
|
551
|
+
{
|
552
|
+
_out << ", ";
|
553
|
+
}
|
554
|
+
_out << getAbsolute(*q, IdentToUpper, "T_") << "Prx";
|
555
|
+
++interfaceCount;
|
556
|
+
}
|
557
|
+
}
|
558
|
+
}
|
559
|
+
_out << "])";
|
670
560
|
|
671
561
|
if(!ops.empty())
|
672
562
|
{
|
@@ -691,7 +581,7 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
691
581
|
break;
|
692
582
|
}
|
693
583
|
|
694
|
-
_out << nl << name << "
|
584
|
+
_out << nl << name << "Prx_mixin::OP_" << (*s)->name() << " = ::Ice::__defineOperation('"
|
695
585
|
<< (*s)->name() << "', ";
|
696
586
|
switch((*s)->mode())
|
697
587
|
{
|
@@ -790,7 +680,7 @@ Slice::Ruby::CodeVisitor::visitClassDefStart(const ClassDefPtr& p)
|
|
790
680
|
{
|
791
681
|
msg = deprecateMetadata.substr(pos + 1);
|
792
682
|
}
|
793
|
-
_out << nl << name << "
|
683
|
+
_out << nl << name << "Prx_mixin::OP_" << (*s)->name() << ".deprecate(\"" << msg << "\")";
|
794
684
|
}
|
795
685
|
}
|
796
686
|
}
|
@@ -880,7 +770,7 @@ Slice::Ruby::CodeVisitor::visitExceptionStart(const ExceptionPtr& p)
|
|
880
770
|
//
|
881
771
|
_out << sp << nl << "def to_s";
|
882
772
|
_out.inc();
|
883
|
-
_out << nl << "'" << scoped
|
773
|
+
_out << nl << "'" << scoped << "'";
|
884
774
|
_out.dec();
|
885
775
|
_out << nl << "end";
|
886
776
|
|
@@ -947,7 +837,6 @@ Slice::Ruby::CodeVisitor::visitExceptionStart(const ExceptionPtr& p)
|
|
947
837
|
_out << nl;
|
948
838
|
}
|
949
839
|
_out << "])";
|
950
|
-
_out << nl << name << "::ICE_TYPE = T_" << name;
|
951
840
|
|
952
841
|
_out.dec();
|
953
842
|
_out << nl << "end"; // if not defined?()
|
@@ -978,6 +867,7 @@ Slice::Ruby::CodeVisitor::visitStructStart(const StructPtr& p)
|
|
978
867
|
_out.inc();
|
979
868
|
_out << nl << "class " << name;
|
980
869
|
_out.inc();
|
870
|
+
_out << nl << "include ::Ice::Inspect_mixin";
|
981
871
|
if(!memberList.empty())
|
982
872
|
{
|
983
873
|
_out << nl << "def initialize(";
|
@@ -1035,15 +925,6 @@ Slice::Ruby::CodeVisitor::visitStructStart(const StructPtr& p)
|
|
1035
925
|
_out.dec();
|
1036
926
|
_out << nl << "end";
|
1037
927
|
|
1038
|
-
//
|
1039
|
-
// inspect
|
1040
|
-
//
|
1041
|
-
_out << sp << nl << "def inspect";
|
1042
|
-
_out.inc();
|
1043
|
-
_out << nl << "::Ice::__stringify(self, T_" << name << ")";
|
1044
|
-
_out.dec();
|
1045
|
-
_out << nl << "end";
|
1046
|
-
|
1047
928
|
//
|
1048
929
|
// read/write accessors for data members.
|
1049
930
|
//
|
@@ -1143,7 +1024,7 @@ Slice::Ruby::CodeVisitor::visitEnum(const EnumPtr& p)
|
|
1143
1024
|
{
|
1144
1025
|
string scoped = p->scoped();
|
1145
1026
|
string name = fixIdent(p->name(), IdentToUpper);
|
1146
|
-
EnumeratorList enums = p->
|
1027
|
+
EnumeratorList enums = p->enumerators();
|
1147
1028
|
|
1148
1029
|
_out << sp << nl << "if not defined?(" << getAbsolute(p, IdentToUpper) << ')';
|
1149
1030
|
_out.inc();
|
@@ -1207,15 +1088,6 @@ Slice::Ruby::CodeVisitor::visitEnum(const EnumPtr& p)
|
|
1207
1088
|
_out.dec();
|
1208
1089
|
_out << nl << "end";
|
1209
1090
|
|
1210
|
-
//
|
1211
|
-
// inspect
|
1212
|
-
//
|
1213
|
-
_out << sp << nl << "def inspect";
|
1214
|
-
_out.inc();
|
1215
|
-
_out << nl << "@name + \"(#{@value})\"";
|
1216
|
-
_out.dec();
|
1217
|
-
_out << nl << "end";
|
1218
|
-
|
1219
1091
|
//
|
1220
1092
|
// each
|
1221
1093
|
//
|
@@ -1328,9 +1200,10 @@ Slice::Ruby::CodeVisitor::writeType(const TypePtr& p)
|
|
1328
1200
|
_out << "::Ice::T_string";
|
1329
1201
|
break;
|
1330
1202
|
}
|
1203
|
+
case Builtin::KindValue:
|
1331
1204
|
case Builtin::KindObject:
|
1332
1205
|
{
|
1333
|
-
_out << "::Ice::
|
1206
|
+
_out << "::Ice::T_Value";
|
1334
1207
|
break;
|
1335
1208
|
}
|
1336
1209
|
case Builtin::KindObjectProxy:
|
@@ -1350,7 +1223,15 @@ Slice::Ruby::CodeVisitor::writeType(const TypePtr& p)
|
|
1350
1223
|
ProxyPtr prx = ProxyPtr::dynamicCast(p);
|
1351
1224
|
if(prx)
|
1352
1225
|
{
|
1353
|
-
|
1226
|
+
ClassDefPtr def = prx->_class()->definition();
|
1227
|
+
if(!def || def->isAbstract())
|
1228
|
+
{
|
1229
|
+
_out << getAbsolute(prx->_class(), IdentToUpper, "T_") << "Prx";
|
1230
|
+
}
|
1231
|
+
else
|
1232
|
+
{
|
1233
|
+
_out << "::Ice::T_ObjectPrx";
|
1234
|
+
}
|
1354
1235
|
return;
|
1355
1236
|
}
|
1356
1237
|
|
@@ -1388,6 +1269,7 @@ Slice::Ruby::CodeVisitor::getInitializer(const DataMemberPtr& m)
|
|
1388
1269
|
{
|
1389
1270
|
return "''";
|
1390
1271
|
}
|
1272
|
+
case Builtin::KindValue:
|
1391
1273
|
case Builtin::KindObject:
|
1392
1274
|
case Builtin::KindObjectProxy:
|
1393
1275
|
case Builtin::KindLocalObject:
|
@@ -1400,7 +1282,7 @@ Slice::Ruby::CodeVisitor::getInitializer(const DataMemberPtr& m)
|
|
1400
1282
|
EnumPtr en = EnumPtr::dynamicCast(p);
|
1401
1283
|
if(en)
|
1402
1284
|
{
|
1403
|
-
EnumeratorList enums = en->
|
1285
|
+
EnumeratorList enums = en->enumerators();
|
1404
1286
|
return getAbsolute(en, IdentToUpper) + "::" + fixIdent(enums.front()->name(), IdentToUpper);
|
1405
1287
|
}
|
1406
1288
|
|
@@ -1455,152 +1337,12 @@ Slice::Ruby::CodeVisitor::writeConstantValue(const TypePtr& type, const SyntaxTr
|
|
1455
1337
|
}
|
1456
1338
|
case Slice::Builtin::KindString:
|
1457
1339
|
{
|
1458
|
-
//
|
1459
|
-
|
1460
|
-
// here because they are sensitive to the current locale.
|
1461
|
-
//
|
1462
|
-
static const string basicSourceChars = "abcdefghijklmnopqrstuvwxyz"
|
1463
|
-
"ABCDEFGHIJKLMNOPQRSTUVWXYZ"
|
1464
|
-
"0123456789"
|
1465
|
-
"_{}[]#()<>%:;.?*+-/^&|~!=, '";
|
1466
|
-
static const set<char> charSet(basicSourceChars.begin(), basicSourceChars.end());
|
1467
|
-
|
1468
|
-
_out << "\""; // Opening "
|
1469
|
-
|
1470
|
-
for(size_t i = 0; i < value.size();)
|
1471
|
-
{
|
1472
|
-
char c = value[i];
|
1473
|
-
switch(c)
|
1474
|
-
{
|
1475
|
-
case '"':
|
1476
|
-
{
|
1477
|
-
_out << "\\\"";
|
1478
|
-
break;
|
1479
|
-
}
|
1480
|
-
case '\\':
|
1481
|
-
{
|
1482
|
-
string s = "\\";
|
1483
|
-
size_t j = i + 1;
|
1484
|
-
for(; j < value.size(); ++j)
|
1485
|
-
{
|
1486
|
-
if(value[j] != '\\')
|
1487
|
-
{
|
1488
|
-
break;
|
1489
|
-
}
|
1490
|
-
s += "\\";
|
1491
|
-
}
|
1492
|
-
|
1493
|
-
//
|
1494
|
-
// An even number of slash \ will escape the backslash and
|
1495
|
-
// the codepoint will be interpreted as its charaters
|
1496
|
-
//
|
1497
|
-
// \\u00000041 - ['\\', 'u', '0', '0', '0', '0', '0', '0', '4', '1']
|
1498
|
-
// \\\u00000041 - ['\\', 'A'] (41 is the codepoint for 'A')
|
1499
|
-
//
|
1500
|
-
if(s.size() % 2 != 0 && (value[j] == 'U' || value[j] == 'u'))
|
1501
|
-
{
|
1502
|
-
//
|
1503
|
-
// Convert codepoint to UTF8 bytes and write the escaped bytes
|
1504
|
-
//
|
1505
|
-
_out << s.substr(0, s.size() - 1);
|
1506
|
-
|
1507
|
-
size_t sz = value[j] == 'U' ? 8 : 4;
|
1508
|
-
string codepoint = value.substr(j + 1, sz);
|
1509
|
-
assert(codepoint.size() == sz);
|
1510
|
-
IceUtil::Int64 v = IceUtilInternal::strToInt64(codepoint.c_str(), 0, 16);
|
1511
|
-
|
1512
|
-
vector<unsigned int> u32buffer;
|
1513
|
-
u32buffer.push_back(static_cast<unsigned int>(v));
|
1514
|
-
|
1515
|
-
vector<unsigned char> u8buffer;
|
1516
|
-
IceUtilInternal::ConversionResult result = convertUTF32ToUTF8(u32buffer, u8buffer, IceUtil::lenientConversion);
|
1517
|
-
switch(result)
|
1518
|
-
{
|
1519
|
-
case conversionOK:
|
1520
|
-
break;
|
1521
|
-
case sourceExhausted:
|
1522
|
-
throw IceUtil::IllegalConversionException(__FILE__, __LINE__, "string source exhausted");
|
1523
|
-
case sourceIllegal:
|
1524
|
-
throw IceUtil::IllegalConversionException(__FILE__, __LINE__, "string source illegal");
|
1525
|
-
default:
|
1526
|
-
{
|
1527
|
-
assert(0);
|
1528
|
-
throw IceUtil::IllegalConversionException(__FILE__, __LINE__);
|
1529
|
-
}
|
1530
|
-
}
|
1531
|
-
|
1532
|
-
ostringstream s;
|
1533
|
-
for(vector<unsigned char>::const_iterator q = u8buffer.begin(); q != u8buffer.end(); ++q)
|
1534
|
-
{
|
1535
|
-
s << "\\";
|
1536
|
-
s.fill('0');
|
1537
|
-
s.width(3);
|
1538
|
-
s << oct;
|
1539
|
-
s << static_cast<unsigned int>(*q);
|
1540
|
-
}
|
1541
|
-
_out << s.str();
|
1542
|
-
|
1543
|
-
i = j + 1 + sz;
|
1544
|
-
}
|
1545
|
-
else
|
1546
|
-
{
|
1547
|
-
_out << s;
|
1548
|
-
i = j;
|
1549
|
-
}
|
1550
|
-
continue;
|
1551
|
-
}
|
1552
|
-
case '\r':
|
1553
|
-
{
|
1554
|
-
_out << "\\r";
|
1555
|
-
break;
|
1556
|
-
}
|
1557
|
-
case '\n':
|
1558
|
-
{
|
1559
|
-
_out << "\\n";
|
1560
|
-
break;
|
1561
|
-
}
|
1562
|
-
case '\t':
|
1563
|
-
{
|
1564
|
-
_out << "\\t";
|
1565
|
-
break;
|
1566
|
-
}
|
1567
|
-
case '\b':
|
1568
|
-
{
|
1569
|
-
_out << "\\b";
|
1570
|
-
break;
|
1571
|
-
}
|
1572
|
-
case '\f':
|
1573
|
-
{
|
1574
|
-
_out << "\\f";
|
1575
|
-
break;
|
1576
|
-
}
|
1577
|
-
default:
|
1578
|
-
{
|
1579
|
-
if(charSet.find(c) == charSet.end())
|
1580
|
-
{
|
1581
|
-
unsigned char uc = c; // Char may be signed, so make it positive.
|
1582
|
-
stringstream s;
|
1583
|
-
s << "\\"; // Print as octal if not in basic source character set.
|
1584
|
-
s.flags(ios_base::oct);
|
1585
|
-
s.width(3);
|
1586
|
-
s.fill('0');
|
1587
|
-
s << static_cast<unsigned>(uc);
|
1588
|
-
_out << s.str();
|
1589
|
-
}
|
1590
|
-
else
|
1591
|
-
{
|
1592
|
-
_out << c; // Print normally if in basic source character set.
|
1593
|
-
}
|
1594
|
-
break;
|
1595
|
-
}
|
1596
|
-
}
|
1597
|
-
++i;
|
1598
|
-
}
|
1599
|
-
|
1600
|
-
_out << "\""; // Closing "
|
1340
|
+
// RubyUCN available in Ruby 1.9 or greater
|
1341
|
+
_out << "\"" << toStringLiteral(value, "\a\b\f\n\r\t\v\x20\x1b", "", EC6UCN, 0) << "\"";
|
1601
1342
|
break;
|
1602
1343
|
}
|
1603
1344
|
|
1345
|
+
case Slice::Builtin::KindValue:
|
1604
1346
|
case Slice::Builtin::KindObject:
|
1605
1347
|
case Slice::Builtin::KindObjectProxy:
|
1606
1348
|
case Slice::Builtin::KindLocalObject:
|
@@ -1609,16 +1351,9 @@ Slice::Ruby::CodeVisitor::writeConstantValue(const TypePtr& type, const SyntaxTr
|
|
1609
1351
|
}
|
1610
1352
|
else if(en)
|
1611
1353
|
{
|
1612
|
-
|
1613
|
-
|
1614
|
-
|
1615
|
-
{
|
1616
|
-
_out << fixIdent(value.substr(colon + 1), IdentToUpper);
|
1617
|
-
}
|
1618
|
-
else
|
1619
|
-
{
|
1620
|
-
_out << fixIdent(value, IdentToUpper);
|
1621
|
-
}
|
1354
|
+
EnumeratorPtr lte = EnumeratorPtr::dynamicCast(valueType);
|
1355
|
+
assert(lte);
|
1356
|
+
_out << getAbsolute(lte, IdentToUpper);
|
1622
1357
|
}
|
1623
1358
|
else
|
1624
1359
|
{
|
@@ -1824,14 +1559,9 @@ void
|
|
1824
1559
|
Slice::Ruby::printHeader(IceUtilInternal::Output& out)
|
1825
1560
|
{
|
1826
1561
|
static const char* header =
|
1827
|
-
"# **********************************************************************\n"
|
1828
|
-
"#\n"
|
1829
|
-
"# Copyright (c) 2003-2018 ZeroC, Inc. All rights reserved.\n"
|
1830
1562
|
"#\n"
|
1831
|
-
"#
|
1832
|
-
"# ICE_LICENSE file included in this distribution.\n"
|
1563
|
+
"# Copyright (c) ZeroC, Inc. All rights reserved.\n"
|
1833
1564
|
"#\n"
|
1834
|
-
"# **********************************************************************\n"
|
1835
1565
|
;
|
1836
1566
|
|
1837
1567
|
out << header;
|