forked from pool/python-tornado
Bug fixes:
- Fixed handling of closed connections with the epoll
(i.e. Linux) IOLoop. Previously, closed connections could be
shut down too early, which most often manifested as “Stream
is closed” exceptions in SimpleAsyncHTTPClient.
- Fixed a case in which chunked responses could be closed
prematurely, leading to truncated output.
- IOStream.connect now reports errors more consistently via
logging and the close callback (this affects e.g. connections
to localhost on FreeBSD).
- IOStream.read_bytes again accepts both int and long arguments.
- PeriodicCallback no longer runs repeatedly when IOLoop
iterations complete faster than the resolution of time.time()
(mainly a problem on Windows).
Backwards-compatibility note
- Listening for IOLoop.ERROR alone is no longer sufficient for
detecting closed connections on an otherwise unused socket.
IOLoop.ERROR must always be used in combination with READ or
WRITE.
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-tornado?expand=0&rev=11
68 lines
2.6 KiB
RPMSpec
68 lines
2.6 KiB
RPMSpec
#
|
|
# spec file for package python-tornado
|
|
#
|
|
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
#
|
|
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
|
#
|
|
|
|
Name: python-tornado
|
|
Version: 2.1.1
|
|
Release: 0
|
|
Url: http://www.tornadoweb.org
|
|
Summary: Open source version of scalable, non-blocking web server that power FriendFeed
|
|
License: Apache-2.0
|
|
Group: Development/Languages/Python
|
|
Source: tornado-%{version}.tar.bz2
|
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
|
BuildRequires: python-devel
|
|
Requires: python-curl
|
|
Requires: python-simplejson
|
|
%if 0%{?suse_version}
|
|
%py_requires
|
|
%if 0%{?suse_version} > 1110
|
|
BuildArch: noarch
|
|
%endif
|
|
%endif
|
|
%{!?python_sitelib: %global python_sitelib %(%{__python} -c "from distutils.sysconfig import get_python_lib; print get_python_lib()")}
|
|
|
|
%description
|
|
Tornado is an open source version of the scalable, non-blocking web server and tools that power FriendFeed.
|
|
The FriendFeed application is written using a web framework that looks a bit like web.py or Google's webapp,
|
|
but with additional tools and optimizations to take advantage of the underlying non-blocking infrastructure.
|
|
|
|
The framework is distinct from most mainstream web server frameworks (and certainly most Python frameworks)
|
|
because it is non-blocking and reasonably fast. Because it is non-blocking and uses epoll, it can handle
|
|
thousands of simultaneous standing connections, which means it is ideal for real-time web services. We built
|
|
the web server specifically to handle FriendFeed's real-time features — every active user of FriendFeed
|
|
maintains an open connection to the FriendFeed servers. (For more information on scaling servers to support
|
|
thousands of clients, see The C10K problem.)
|
|
|
|
%prep
|
|
%setup -q -n tornado-%{version}
|
|
|
|
%build
|
|
CFLAGS="%{optflags}" python setup.py build
|
|
|
|
%install
|
|
python setup.py install --prefix=%{_prefix} --root=%{buildroot}
|
|
|
|
%clean
|
|
rm -rf %{buildroot}
|
|
|
|
%files
|
|
%defattr(-,root,root,-)
|
|
%doc README demos
|
|
%{python_sitelib}/*
|
|
|
|
%changelog
|