{-# LANGUAGE TypeApplications #-}
#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif
module GI.Gio.Objects.SimpleIOStream
(
SimpleIOStream(..) ,
IsSimpleIOStream ,
toSimpleIOStream ,
#if defined(ENABLE_OVERLOADING)
ResolveSimpleIOStreamMethod ,
#endif
simpleIOStreamNew ,
#if defined(ENABLE_OVERLOADING)
SimpleIOStreamInputStreamPropertyInfo ,
#endif
constructSimpleIOStreamInputStream ,
getSimpleIOStreamInputStream ,
#if defined(ENABLE_OVERLOADING)
simpleIOStreamInputStream ,
#endif
#if defined(ENABLE_OVERLOADING)
SimpleIOStreamOutputStreamPropertyInfo ,
#endif
constructSimpleIOStreamOutputStream ,
getSimpleIOStreamOutputStream ,
#if defined(ENABLE_OVERLOADING)
simpleIOStreamOutputStream ,
#endif
) where
import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P
import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.BasicTypes as B.Types
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GArray as B.GArray
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GHashTable as B.GHT
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GValue as B.GValue
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.GI.Base.Properties as B.Properties
import qualified Data.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
import qualified Data.Coerce as Coerce
import qualified Data.Text as T
import qualified Data.Kind as DK
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GHC.OverloadedLabels as OL
import qualified GHC.Records as R
import qualified Data.Word as DW
import qualified Data.Int as DI
import qualified System.Posix.Types as SPT
import qualified Foreign.C.Types as FCT
#if MIN_VERSION_base(4,18,0)
import qualified GI.GLib.Callbacks as GLib.Callbacks
import qualified GI.GLib.Structs.Bytes as GLib.Bytes
import qualified GI.GLib.Structs.PollFD as GLib.PollFD
import qualified GI.GLib.Structs.Source as GLib.Source
import qualified GI.GObject.Callbacks as GObject.Callbacks
import qualified GI.GObject.Objects.Object as GObject.Object
import qualified GI.Gio.Callbacks as Gio.Callbacks
import {-# SOURCE #-} qualified GI.Gio.Flags as Gio.Flags
import {-# SOURCE #-} qualified GI.Gio.Interfaces.AsyncResult as Gio.AsyncResult
import {-# SOURCE #-} qualified GI.Gio.Objects.Cancellable as Gio.Cancellable
import {-# SOURCE #-} qualified GI.Gio.Objects.IOStream as Gio.IOStream
import {-# SOURCE #-} qualified GI.Gio.Objects.InputStream as Gio.InputStream
import {-# SOURCE #-} qualified GI.Gio.Objects.OutputStream as Gio.OutputStream
import {-# SOURCE #-} qualified GI.Gio.Structs.OutputVector as Gio.OutputVector
#else
import qualified GI.GObject.Objects.Object as GObject.Object
import {-# SOURCE #-} qualified GI.Gio.Objects.IOStream as Gio.IOStream
import {-# SOURCE #-} qualified GI.Gio.Objects.InputStream as Gio.InputStream
import {-# SOURCE #-} qualified GI.Gio.Objects.OutputStream as Gio.OutputStream
#endif
newtype SimpleIOStream = SimpleIOStream (SP.ManagedPtr SimpleIOStream)
deriving (SimpleIOStream -> SimpleIOStream -> Bool
(SimpleIOStream -> SimpleIOStream -> Bool)
-> (SimpleIOStream -> SimpleIOStream -> Bool) -> Eq SimpleIOStream
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SimpleIOStream -> SimpleIOStream -> Bool
== :: SimpleIOStream -> SimpleIOStream -> Bool
$c/= :: SimpleIOStream -> SimpleIOStream -> Bool
/= :: SimpleIOStream -> SimpleIOStream -> Bool
Eq)
instance SP.ManagedPtrNewtype SimpleIOStream where
toManagedPtr :: SimpleIOStream -> ManagedPtr SimpleIOStream
toManagedPtr (SimpleIOStream ManagedPtr SimpleIOStream
p) = ManagedPtr SimpleIOStream
p
foreign import ccall "g_simple_io_stream_get_type"
c_g_simple_io_stream_get_type :: IO B.Types.GType
instance B.Types.TypedObject SimpleIOStream where
glibType :: IO GType
glibType = IO GType
c_g_simple_io_stream_get_type
instance B.Types.GObject SimpleIOStream
class (SP.GObject o, O.IsDescendantOf SimpleIOStream o) => IsSimpleIOStream o
instance (SP.GObject o, O.IsDescendantOf SimpleIOStream o) => IsSimpleIOStream o
instance O.HasParentTypes SimpleIOStream
type instance O.ParentTypes SimpleIOStream = '[Gio.IOStream.IOStream, GObject.Object.Object]
toSimpleIOStream :: (MIO.MonadIO m, IsSimpleIOStream o) => o -> m SimpleIOStream
toSimpleIOStream :: forall (m :: * -> *) o.
(MonadIO m, IsSimpleIOStream o) =>
o -> m SimpleIOStream
toSimpleIOStream = IO SimpleIOStream -> m SimpleIOStream
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO SimpleIOStream -> m SimpleIOStream)
-> (o -> IO SimpleIOStream) -> o -> m SimpleIOStream
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (ManagedPtr SimpleIOStream -> SimpleIOStream)
-> o -> IO SimpleIOStream
forall o o'.
(HasCallStack, ManagedPtrNewtype o, TypedObject o,
ManagedPtrNewtype o', TypedObject o') =>
(ManagedPtr o' -> o') -> o -> IO o'
B.ManagedPtr.unsafeCastTo ManagedPtr SimpleIOStream -> SimpleIOStream
SimpleIOStream
instance B.GValue.IsGValue (Maybe SimpleIOStream) where
gvalueGType_ :: IO GType
gvalueGType_ = IO GType
c_g_simple_io_stream_get_type
gvalueSet_ :: Ptr GValue -> Maybe SimpleIOStream -> IO ()
gvalueSet_ Ptr GValue
gv Maybe SimpleIOStream
P.Nothing = Ptr GValue -> Ptr SimpleIOStream -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv (Ptr SimpleIOStream
forall a. Ptr a
FP.nullPtr :: FP.Ptr SimpleIOStream)
gvalueSet_ Ptr GValue
gv (P.Just SimpleIOStream
obj) = SimpleIOStream -> (Ptr SimpleIOStream -> IO ()) -> IO ()
forall a c.
(HasCallStack, ManagedPtrNewtype a) =>
a -> (Ptr a -> IO c) -> IO c
B.ManagedPtr.withManagedPtr SimpleIOStream
obj (Ptr GValue -> Ptr SimpleIOStream -> IO ()
forall a. GObject a => Ptr GValue -> Ptr a -> IO ()
B.GValue.set_object Ptr GValue
gv)
gvalueGet_ :: Ptr GValue -> IO (Maybe SimpleIOStream)
gvalueGet_ Ptr GValue
gv = do
ptr <- Ptr GValue -> IO (Ptr SimpleIOStream)
forall a. GObject a => Ptr GValue -> IO (Ptr a)
B.GValue.get_object Ptr GValue
gv :: IO (FP.Ptr SimpleIOStream)
if ptr /= FP.nullPtr
then P.Just <$> B.ManagedPtr.newObject SimpleIOStream ptr
else return P.Nothing
#if defined(ENABLE_OVERLOADING)
type family ResolveSimpleIOStreamMethod (t :: Symbol) (o :: DK.Type) :: DK.Type where
ResolveSimpleIOStreamMethod "bindProperty" o = GObject.Object.ObjectBindPropertyMethodInfo
ResolveSimpleIOStreamMethod "bindPropertyFull" o = GObject.Object.ObjectBindPropertyFullMethodInfo
ResolveSimpleIOStreamMethod "clearPending" o = Gio.IOStream.IOStreamClearPendingMethodInfo
ResolveSimpleIOStreamMethod "close" o = Gio.IOStream.IOStreamCloseMethodInfo
ResolveSimpleIOStreamMethod "closeAsync" o = Gio.IOStream.IOStreamCloseAsyncMethodInfo
ResolveSimpleIOStreamMethod "closeFinish" o = Gio.IOStream.IOStreamCloseFinishMethodInfo
ResolveSimpleIOStreamMethod "forceFloating" o = GObject.Object.ObjectForceFloatingMethodInfo
ResolveSimpleIOStreamMethod "freezeNotify" o = GObject.Object.ObjectFreezeNotifyMethodInfo
ResolveSimpleIOStreamMethod "getv" o = GObject.Object.ObjectGetvMethodInfo
ResolveSimpleIOStreamMethod "hasPending" o = Gio.IOStream.IOStreamHasPendingMethodInfo
ResolveSimpleIOStreamMethod "isClosed" o = Gio.IOStream.IOStreamIsClosedMethodInfo
ResolveSimpleIOStreamMethod "isFloating" o = GObject.Object.ObjectIsFloatingMethodInfo
ResolveSimpleIOStreamMethod "notify" o = GObject.Object.ObjectNotifyMethodInfo
ResolveSimpleIOStreamMethod "notifyByPspec" o = GObject.Object.ObjectNotifyByPspecMethodInfo
ResolveSimpleIOStreamMethod "ref" o = GObject.Object.ObjectRefMethodInfo
ResolveSimpleIOStreamMethod "refSink" o = GObject.Object.ObjectRefSinkMethodInfo
ResolveSimpleIOStreamMethod "runDispose" o = GObject.Object.ObjectRunDisposeMethodInfo
ResolveSimpleIOStreamMethod "spliceAsync" o = Gio.IOStream.IOStreamSpliceAsyncMethodInfo
ResolveSimpleIOStreamMethod "stealData" o = GObject.Object.ObjectStealDataMethodInfo
ResolveSimpleIOStreamMethod "stealQdata" o = GObject.Object.ObjectStealQdataMethodInfo
ResolveSimpleIOStreamMethod "thawNotify" o = GObject.Object.ObjectThawNotifyMethodInfo
ResolveSimpleIOStreamMethod "unref" o = GObject.Object.ObjectUnrefMethodInfo
ResolveSimpleIOStreamMethod "watchClosure" o = GObject.Object.ObjectWatchClosureMethodInfo
ResolveSimpleIOStreamMethod "getData" o = GObject.Object.ObjectGetDataMethodInfo
ResolveSimpleIOStreamMethod "getInputStream" o = Gio.IOStream.IOStreamGetInputStreamMethodInfo
ResolveSimpleIOStreamMethod "getOutputStream" o = Gio.IOStream.IOStreamGetOutputStreamMethodInfo
ResolveSimpleIOStreamMethod "getProperty" o = GObject.Object.ObjectGetPropertyMethodInfo
ResolveSimpleIOStreamMethod "getQdata" o = GObject.Object.ObjectGetQdataMethodInfo
ResolveSimpleIOStreamMethod "setData" o = GObject.Object.ObjectSetDataMethodInfo
ResolveSimpleIOStreamMethod "setDataFull" o = GObject.Object.ObjectSetDataFullMethodInfo
ResolveSimpleIOStreamMethod "setPending" o = Gio.IOStream.IOStreamSetPendingMethodInfo
ResolveSimpleIOStreamMethod "setProperty" o = GObject.Object.ObjectSetPropertyMethodInfo
ResolveSimpleIOStreamMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveSimpleIOStreamMethod t SimpleIOStream, O.OverloadedMethod info SimpleIOStream p) => OL.IsLabel t (SimpleIOStream -> p) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.overloadedMethod @info
#else
fromLabel _ = O.overloadedMethod @info
#endif
#if MIN_VERSION_base(4,13,0)
instance (info ~ ResolveSimpleIOStreamMethod t SimpleIOStream, O.OverloadedMethod info SimpleIOStream p, R.HasField t SimpleIOStream p) => R.HasField t SimpleIOStream p where
getField = O.overloadedMethod @info
#endif
instance (info ~ ResolveSimpleIOStreamMethod t SimpleIOStream, O.OverloadedMethodInfo info SimpleIOStream) => OL.IsLabel t (O.MethodProxy info SimpleIOStream) where
#if MIN_VERSION_base(4,10,0)
fromLabel = O.MethodProxy
#else
fromLabel _ = O.MethodProxy
#endif
#endif
getSimpleIOStreamInputStream :: (MonadIO m, IsSimpleIOStream o) => o -> m (Maybe Gio.InputStream.InputStream)
getSimpleIOStreamInputStream :: forall (m :: * -> *) o.
(MonadIO m, IsSimpleIOStream o) =>
o -> m (Maybe InputStream)
getSimpleIOStreamInputStream o
obj = IO (Maybe InputStream) -> m (Maybe InputStream)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe InputStream) -> m (Maybe InputStream))
-> IO (Maybe InputStream) -> m (Maybe InputStream)
forall a b. (a -> b) -> a -> b
$ o
-> String
-> (ManagedPtr InputStream -> InputStream)
-> IO (Maybe InputStream)
forall a b.
(GObject a, GObject b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyObject o
obj String
"input-stream" ManagedPtr InputStream -> InputStream
Gio.InputStream.InputStream
constructSimpleIOStreamInputStream :: (IsSimpleIOStream o, MIO.MonadIO m, Gio.InputStream.IsInputStream a) => a -> m (GValueConstruct o)
constructSimpleIOStreamInputStream :: forall o (m :: * -> *) a.
(IsSimpleIOStream o, MonadIO m, IsInputStream a) =>
a -> m (GValueConstruct o)
constructSimpleIOStreamInputStream a
val = IO (GValueConstruct o) -> m (GValueConstruct o)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> m (GValueConstruct o))
-> IO (GValueConstruct o) -> m (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ do
IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> IO (GValueConstruct o))
-> IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ String -> Maybe a -> IO (GValueConstruct o)
forall a o.
GObject a =>
String -> Maybe a -> IO (GValueConstruct o)
B.Properties.constructObjectPropertyObject String
"input-stream" (a -> Maybe a
forall a. a -> Maybe a
P.Just a
val)
#if defined(ENABLE_OVERLOADING)
data SimpleIOStreamInputStreamPropertyInfo
instance AttrInfo SimpleIOStreamInputStreamPropertyInfo where
type AttrAllowedOps SimpleIOStreamInputStreamPropertyInfo = '[ 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint SimpleIOStreamInputStreamPropertyInfo = IsSimpleIOStream
type AttrSetTypeConstraint SimpleIOStreamInputStreamPropertyInfo = Gio.InputStream.IsInputStream
type AttrTransferTypeConstraint SimpleIOStreamInputStreamPropertyInfo = Gio.InputStream.IsInputStream
type AttrTransferType SimpleIOStreamInputStreamPropertyInfo = Gio.InputStream.InputStream
type AttrGetType SimpleIOStreamInputStreamPropertyInfo = (Maybe Gio.InputStream.InputStream)
type AttrLabel SimpleIOStreamInputStreamPropertyInfo = "input-stream"
type AttrOrigin SimpleIOStreamInputStreamPropertyInfo = SimpleIOStream
attrGet = getSimpleIOStreamInputStream
attrSet = undefined
attrTransfer _ v = do
unsafeCastTo Gio.InputStream.InputStream v
attrConstruct = constructSimpleIOStreamInputStream
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gio.Objects.SimpleIOStream.inputStream"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gio-2.0.35/docs/GI-Gio-Objects-SimpleIOStream.html#g:attr:inputStream"
})
#endif
getSimpleIOStreamOutputStream :: (MonadIO m, IsSimpleIOStream o) => o -> m (Maybe Gio.OutputStream.OutputStream)
getSimpleIOStreamOutputStream :: forall (m :: * -> *) o.
(MonadIO m, IsSimpleIOStream o) =>
o -> m (Maybe OutputStream)
getSimpleIOStreamOutputStream o
obj = IO (Maybe OutputStream) -> m (Maybe OutputStream)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (Maybe OutputStream) -> m (Maybe OutputStream))
-> IO (Maybe OutputStream) -> m (Maybe OutputStream)
forall a b. (a -> b) -> a -> b
$ o
-> String
-> (ManagedPtr OutputStream -> OutputStream)
-> IO (Maybe OutputStream)
forall a b.
(GObject a, GObject b) =>
a -> String -> (ManagedPtr b -> b) -> IO (Maybe b)
B.Properties.getObjectPropertyObject o
obj String
"output-stream" ManagedPtr OutputStream -> OutputStream
Gio.OutputStream.OutputStream
constructSimpleIOStreamOutputStream :: (IsSimpleIOStream o, MIO.MonadIO m, Gio.OutputStream.IsOutputStream a) => a -> m (GValueConstruct o)
constructSimpleIOStreamOutputStream :: forall o (m :: * -> *) a.
(IsSimpleIOStream o, MonadIO m, IsOutputStream a) =>
a -> m (GValueConstruct o)
constructSimpleIOStreamOutputStream a
val = IO (GValueConstruct o) -> m (GValueConstruct o)
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> m (GValueConstruct o))
-> IO (GValueConstruct o) -> m (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ do
IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
MIO.liftIO (IO (GValueConstruct o) -> IO (GValueConstruct o))
-> IO (GValueConstruct o) -> IO (GValueConstruct o)
forall a b. (a -> b) -> a -> b
$ String -> Maybe a -> IO (GValueConstruct o)
forall a o.
GObject a =>
String -> Maybe a -> IO (GValueConstruct o)
B.Properties.constructObjectPropertyObject String
"output-stream" (a -> Maybe a
forall a. a -> Maybe a
P.Just a
val)
#if defined(ENABLE_OVERLOADING)
data SimpleIOStreamOutputStreamPropertyInfo
instance AttrInfo SimpleIOStreamOutputStreamPropertyInfo where
type AttrAllowedOps SimpleIOStreamOutputStreamPropertyInfo = '[ 'AttrConstruct, 'AttrGet, 'AttrClear]
type AttrBaseTypeConstraint SimpleIOStreamOutputStreamPropertyInfo = IsSimpleIOStream
type AttrSetTypeConstraint SimpleIOStreamOutputStreamPropertyInfo = Gio.OutputStream.IsOutputStream
type AttrTransferTypeConstraint SimpleIOStreamOutputStreamPropertyInfo = Gio.OutputStream.IsOutputStream
type AttrTransferType SimpleIOStreamOutputStreamPropertyInfo = Gio.OutputStream.OutputStream
type AttrGetType SimpleIOStreamOutputStreamPropertyInfo = (Maybe Gio.OutputStream.OutputStream)
type AttrLabel SimpleIOStreamOutputStreamPropertyInfo = "output-stream"
type AttrOrigin SimpleIOStreamOutputStreamPropertyInfo = SimpleIOStream
attrGet = getSimpleIOStreamOutputStream
attrSet = undefined
attrTransfer _ v = do
unsafeCastTo Gio.OutputStream.OutputStream v
attrConstruct = constructSimpleIOStreamOutputStream
attrClear = undefined
dbgAttrInfo = P.Just (O.ResolvedSymbolInfo {
O.resolvedSymbolName = "GI.Gio.Objects.SimpleIOStream.outputStream"
, O.resolvedSymbolURL = "https://hackage.haskell.org/package/gi-gio-2.0.35/docs/GI-Gio-Objects-SimpleIOStream.html#g:attr:outputStream"
})
#endif
#if defined(ENABLE_OVERLOADING)
instance O.HasAttributeList SimpleIOStream
type instance O.AttributeList SimpleIOStream = SimpleIOStreamAttributeList
type SimpleIOStreamAttributeList = ('[ '("closed", Gio.IOStream.IOStreamClosedPropertyInfo), '("inputStream", SimpleIOStreamInputStreamPropertyInfo), '("outputStream", SimpleIOStreamOutputStreamPropertyInfo)] :: [(Symbol, DK.Type)])
#endif
#if defined(ENABLE_OVERLOADING)
simpleIOStreamInputStream :: AttrLabelProxy "inputStream"
simpleIOStreamInputStream = AttrLabelProxy
simpleIOStreamOutputStream :: AttrLabelProxy "outputStream"
simpleIOStreamOutputStream = AttrLabelProxy
#endif
#if defined(ENABLE_OVERLOADING)
type instance O.SignalList SimpleIOStream = SimpleIOStreamSignalList
type SimpleIOStreamSignalList = ('[ '("notify", GObject.Object.ObjectNotifySignalInfo)] :: [(Symbol, DK.Type)])
#endif
foreign import ccall "g_simple_io_stream_new" g_simple_io_stream_new ::
Ptr Gio.InputStream.InputStream ->
Ptr Gio.OutputStream.OutputStream ->
IO (Ptr SimpleIOStream)
simpleIOStreamNew ::
(B.CallStack.HasCallStack, MonadIO m, Gio.InputStream.IsInputStream a, Gio.OutputStream.IsOutputStream b) =>
a
-> b
-> m SimpleIOStream
simpleIOStreamNew :: forall (m :: * -> *) a b.
(HasCallStack, MonadIO m, IsInputStream a, IsOutputStream b) =>
a -> b -> m SimpleIOStream
simpleIOStreamNew a
inputStream b
outputStream = IO SimpleIOStream -> m SimpleIOStream
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO SimpleIOStream -> m SimpleIOStream)
-> IO SimpleIOStream -> m SimpleIOStream
forall a b. (a -> b) -> a -> b
$ do
inputStream' <- a -> IO (Ptr InputStream)
forall a b. (HasCallStack, ManagedPtrNewtype a) => a -> IO (Ptr b)
unsafeManagedPtrCastPtr a
inputStream
outputStream' <- unsafeManagedPtrCastPtr outputStream
result <- g_simple_io_stream_new inputStream' outputStream'
checkUnexpectedReturnNULL "simpleIOStreamNew" result
result' <- (wrapObject SimpleIOStream) result
touchManagedPtr inputStream
touchManagedPtr outputStream
return result'
#if defined(ENABLE_OVERLOADING)
#endif