Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
D
dlib
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
钟尚武
dlib
Commits
c53848a0
Commit
c53848a0
authored
Nov 17, 2012
by
Davis King
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added an iosockstream object.
parent
ee24b9f8
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
316 additions
and
0 deletions
+316
-0
iosockstream.h
dlib/iosockstream.h
+11
-0
iosockstream.h
dlib/iosockstream/iosockstream.h
+139
-0
iosockstream_abstract.h
dlib/iosockstream/iosockstream_abstract.h
+166
-0
No files found.
dlib/iosockstream.h
0 → 100644
View file @
c53848a0
// Copyright (C) 2012 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#ifndef DLIB_IOSOCkSTREAM_H___
#define DLIB_IOSOCkSTREAM_H___
#include "iosockstream/iosockstream.h"
#endif // DLIB_IOSOCkSTREAM_H___
dlib/iosockstream/iosockstream.h
0 → 100644
View file @
c53848a0
// Copyright (C) 2012 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#ifndef DLIB_IOSOCKSTrEAM_H__
#define DLIB_IOSOCKSTrEAM_H__
#include "iosockstream_abstract.h"
#include <iostream>
#include "../sockstreambuf.h"
#include "../smart_pointers_thread_safe.h"
#include "../timeout.h"
namespace
dlib
{
// ----------------------------------------------------------------------------------------
class
iosockstream
:
public
std
::
iostream
{
public
:
iosockstream
()
{
tie
(
this
);
}
iosockstream
(
const
network_address
&
addr
)
{
tie
(
this
);
open
(
addr
);
}
iosockstream
(
const
network_address
&
addr
,
unsigned
long
timeout
)
{
tie
(
this
);
open
(
addr
,
timeout
);
}
~
iosockstream
()
{
close
();
}
void
open
(
const
network_address
&
addr
)
{
close
();
con
.
reset
(
connect
(
addr
));
buf
.
reset
(
new
sockstreambuf
(
con
.
get
()));
rdbuf
(
buf
.
get
());
clear
();
}
void
open
(
const
network_address
&
addr
,
unsigned
long
timeout
)
{
close
(
timeout
);
con
.
reset
(
connect
(
addr
.
host_address
,
addr
.
port
,
timeout
));
buf
.
reset
(
new
sockstreambuf
(
con
.
get
()));
rdbuf
(
buf
.
get
());
clear
();
}
void
close
(
unsigned
long
timeout
=
10000
)
{
rdbuf
(
0
);
try
{
if
(
buf
)
{
timeout
::
kernel_1a
t
(
*
con
,
&
connection
::
shutdown
,
timeout
);
// This will flush the sockstreambuf and also destroy it.
buf
.
reset
();
if
(
con
->
shutdown_outgoing
())
{
// there was an error so just close it now and return
con
->
shutdown
();
}
else
{
char
junk
[
100
];
// wait for the other end to close their side
while
(
con
->
read
(
junk
,
sizeof
(
junk
))
>
0
);
}
}
}
catch
(...)
{
con
.
reset
();
throw
;
}
con
.
reset
();
}
void
terminate_connection_after_timeout
(
unsigned
long
timeout
)
{
if
(
con
)
{
con_timeout
.
reset
(
new
timeout
::
kernel_1a
(
*
this
,
&
iosockstream
::
terminate_connection
,
timeout
,
con
));
}
}
private
:
void
terminate_connection
(
shared_ptr_thread_safe
<
connection
>
thecon
)
{
thecon
->
shutdown
();
}
scoped_ptr
<
timeout
::
kernel_1a
>
con_timeout
;
shared_ptr_thread_safe
<
connection
>
con
;
scoped_ptr
<
sockstreambuf
>
buf
;
};
// ----------------------------------------------------------------------------------------
}
#endif // DLIB_IOSOCKSTrEAM_H__
dlib/iosockstream/iosockstream_abstract.h
0 → 100644
View file @
c53848a0
// Copyright (C) 2012 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#undef DLIB_IOSOCKSTrEAM_ABSTRACT_H__
#ifdef DLIB_IOSOCKSTrEAM_ABSTRACT_H__
#include "../sockstreambuf/sockstreambuf_abstract.h"
#include <iostream>
namespace
dlib
{
// ----------------------------------------------------------------------------------------
class
iosockstream
:
public
std
::
iostream
{
/*!
WHAT THIS OBJECT REPRESENTS
This is an iostream object that reads/writes from a TCP network connection.
THREAD SAFETY
It is not safe to touch this object from more than one thread at a time.
Therefore, you should mutex lock it if you need to do so.
!*/
public
:
iosockstream
(
);
/*!
ensures
- #good() == false
- #tie() == this
(i.e. Any attempt to read from this stream will automatically flush the
stream's output buffers)
!*/
iosockstream
(
const
network_address
&
addr
);
/*!
ensures
- #tie() == this
(i.e. Any attempt to read from this stream will automatically flush the
stream's output buffers)
- Attempts to connect to the given network address.
- Calling this constructor is equivalent to calling the default constructor
and then invoking open(addr).
- #good() == true
throws
- dlib::socket_error
This exception is thrown if there is some problem that prevents us from
creating the connection.
!*/
iosockstream
(
const
network_address
&
addr
,
unsigned
long
timeout
);
/*!
ensures
- #tie() == this
(i.e. Any attempt to read from this stream will automatically flush the
stream's output buffers)
- Attempts to connect to the given network address.
- Calling this constructor is equivalent to calling the default constructor
and then invoking open(addr, timeout).
- #good() == true
throws
- dlib::socket_error
This exception is thrown if there is some problem that prevents us from
creating the connection or if timeout milliseconds elapses before the
connect is successful.
!*/
~
iosockstream
(
);
/*!
ensures
- Invokes close() before destructing the stream. Therefore, any open
connection will be gracefully closed using the default timeout time.
This also means any data in the stream will be flushed to the connection.
!*/
void
open
(
const
network_address
&
addr
);
/*!
ensures
- This object will attempt to create a TCP connection with the remote host
indicated by addr.
- Any previous connection in this iosockstream is closed by calling close()
before we make any new connection.
- #good() == true
(i.e. the error flags are reset by calling open())
throws
- dlib::socket_error
This exception is thrown if there is some problem that prevents us from
creating the connection.
!*/
void
open
(
const
network_address
&
addr
,
unsigned
long
timeout
);
/*!
ensures
- This object will attempt to create a TCP connection with the remote host
indicated by addr.
- Any previous connection in this iosockstream is closed by calling close()
before we make any new connection.
- #good() == true
(i.e. the error flags are reset by calling open())
throws
- dlib::socket_error
This exception is thrown if there is some problem that prevents us from
creating the connection or if timeout milliseconds elapses before the
connect is successful.
!*/
void
close
(
unsigned
long
timeout
=
10000
);
/*!
ensures
- #good() == false
- if (there is an active TCP connection) then
- Flushes any data buffered in the output part of the stream
to the connection.
- Performs a proper graceful close (i.e. like dlib::close_gracefully()).
- Will only wait timeout milliseconds for the buffer flush and graceful
close to finish before the connection is terminated forcefully.
Therefore, close() will only block for at most timeout milliseconds.
!*/
void
terminate_connection_after_timeout
(
unsigned
long
timeout
);
/*!
ensures
- if (there is an active TCP connection) then
- Any operations on this TCP connection will return error or
end-of-file once timeout milliseconds have elapsed from this call to
terminate_connection_after_timeout(). This is true unless another
call to terminate_connection_after_timeout() is made which gives a
new time. In this case, the previous call is forgotten and the
timeout is reset.
- This timeout only applies to the current TCP connection. That is, if
the iosockstream is closed and a new connection is established, any
previous timeouts setup by terminate_connection_after_timeout() do
not apply.
- else
- This function has no effect on this object.
!*/
};
// ----------------------------------------------------------------------------------------
}
#endif // DLIB_IOSOCKSTrEAM_ABSTRACT_H__
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment