~ubuntu-branches/ubuntu/saucy/gnash/saucy-proposed

« back to all changes in this revision

Viewing changes to libnet/statistics.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Alexander Sack
  • Date: 2008-10-13 14:29:49 UTC
  • mfrom: (1.1.9 upstream)
  • Revision ID: james.westby@ubuntu.com-20081013142949-f6qdvnu4mn05ltdc
Tags: 0.8.4~~bzr9980-0ubuntu1
* new upstream release 0.8.4 (LP: #240325)
* ship new lib usr/lib/gnash/libmozsdk.so.* in mozilla-plugin-gnash
  - update debian/mozilla-plugin-gnash.install
* ship new lib usr/lib/gnash/libgnashnet.so.* in gnash-common
  - update debian/gnash-common.install
* add basic debian/build_head script to build latest CVS head packages.
  - add debian/build_head
* new sound architecture requires build depend on libsdl1.2-dev
  - update debian/control
* head build script now has been completely migrated to bzr (upstream +
  ubuntu)
  - update debian/build_head
* disable kde gui until klash/qt4 has been fixed; keep kde packages as empty
  packages for now.
  - update debian/rules
  - debian/klash.install
  - debian/klash.links
  - debian/klash.manpages
  - debian/konqueror-plugin-gnash.install
* drop libkonq5-dev build dependency accordingly
  - update debian/control
* don't install headers manually anymore. gnash doesnt provide a -dev
  package after all
  - update debian/rules
* update libs installed in gnash-common; libgnashserver-*.so is not available
  anymore (removed); in turn we add the new libgnashcore-*.so
  - update debian/gnash-common.install
* use -Os for optimization and properly pass CXXFLAGS=$(CFLAGS) to configure
  - update debian/rules
* touch firefox .autoreg in postinst of mozilla plugin
  - update debian/mozilla-plugin-gnash.postinst
* link gnash in ubufox plugins directory for the plugin alternative switcher
  - add debian/mozilla-plugin-gnash.links
* suggest ubufox accordingly
  - update debian/control
* add new required build-depends on libgif-dev
  - update debian/control
* add Xb-Npp-Description and Xb-Npp-File as new plugin database meta data
  - update debian/control

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// statistics.cpp:  Network performance stats for Cygnal, for Gnash.
 
2
// 
 
3
//   Copyright (C) 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
 
4
// 
 
5
// This program is free software; you can redistribute it and/or modify
 
6
// it under the terms of the GNU General Public License as published by
 
7
// the Free Software Foundation; either version 3 of the License, or
 
8
// (at your option) any later version.
 
9
// 
 
10
// This program is distributed in the hope that it will be useful,
 
11
// but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
// GNU General Public License for more details.
 
14
//
 
15
// You should have received a copy of the GNU General Public License
 
16
// along with this program; if not, write to the Free Software
 
17
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
18
//
 
19
 
 
20
 
 
21
#ifdef HAVE_CONFIG_H
 
22
#include "gnashconfig.h"
 
23
#endif
 
24
 
 
25
#include <boost/thread/mutex.hpp>
 
26
#include <string>
 
27
#include <list>
 
28
#include <iostream>
 
29
 
 
30
#include "log.h"
 
31
#include "netstats.h"
 
32
#include "statistics.h"
 
33
 
 
34
using namespace gnash;
 
35
using namespace std;
 
36
 
 
37
static boost::mutex io_mutex;
 
38
 
 
39
// The string versions of the codec, used for debugging. If you add
 
40
// another enum type to codec_e, you have to add the string
 
41
// representation here or you'll get the wrong output.
 
42
const char *codec_names[] = {
 
43
    "NO_CODEC",
 
44
    "Ogg",
 
45
    "Theora",
 
46
    "Dirac",
 
47
    "Snow",
 
48
    "MP3",
 
49
    "MPEG4",
 
50
    "H264",
 
51
    "H263",
 
52
    "FLV",
 
53
    "VP6",
 
54
    "VP7"
 
55
};
 
56
 
 
57
// The string versions of the file type, used for debugging. If you add
 
58
// another enum type to filetypes_e, you have to add the string
 
59
// representation here or you'll get the wrong output.
 
60
const char *filetype_names[] = {
 
61
        "NO_FILETYPE",
 
62
        "HTTP",
 
63
        "RTMP",
 
64
        "RTMPT",
 
65
        "RTMPTS",
 
66
        "SWF",
 
67
        "SWF5",
 
68
        "SWF6",
 
69
        "SWF7",
 
70
        "SWF8",
 
71
        "SWF9",
 
72
        "AUDIO",
 
73
        "VIDEO"
 
74
};
 
75
 
 
76
namespace gnash 
 
77
{
 
78
 
 
79
Statistics::Statistics() {
 
80
}
 
81
 
 
82
Statistics::~Statistics() {
 
83
    dump();
 
84
}
 
85
 
 
86
float
 
87
Statistics::getFPS() {
 
88
        return 0.0; // TODO: FIXME !
 
89
}
 
90
 
 
91
int
 
92
Statistics::getBitRate() {
 
93
 
 
94
    return (getStartTime() - getStopTime()).seconds() / getBytes();
 
95
}
 
96
 
 
97
int
 
98
Statistics::addStats() {
 
99
    NetStats *st = new NetStats;
 
100
 
 
101
    st->setStartTime(getStartTime());
 
102
    st->setStopTime(getStopTime());
 
103
    st->setBytes(getBytes());
 
104
    st->setFileType(getFileType());
 
105
    
 
106
    boost::mutex::scoped_lock lock(io_mutex);
 
107
    _netstats.push_back(st);
 
108
    
 
109
    return _netstats.size();
 
110
}
 
111
 
 
112
void
 
113
Statistics::dump() {   
 
114
    boost::mutex::scoped_lock lock(io_mutex);
 
115
    list<NetStats *>::iterator it;
 
116
 
 
117
    for (it = _netstats.begin(); it != _netstats.end(); it++) {
 
118
        NetStats *stats = (*it);
 
119
        if (stats->getFileType() <= VIDEO) {
 
120
            log_debug (_("Stream type is: %s"), filetype_names[stats->getFileType()]);
 
121
        }
 
122
//         if (((stats->getFileType() == VIDEO) || (stats->getFileType() == AUDIO)) &&
 
123
//             stats->getCodec() <= VP7) {
 
124
//             log_debug (_("Stream codec is: %s"), codec_names[stats->getCodec()]);
 
125
//         }
 
126
        log_debug (_("%d bytes were transfered in %s seconds"),
 
127
                 stats->getBytes(),
 
128
                 to_simple_string(stats->getTimeSpan()).c_str());
 
129
    }
 
130
}
 
131
 
 
132
} // end of gnash namespace
 
133
 
 
134
// local Variables:
 
135
// mode: C++
 
136
// indent-tabs-mode: t
 
137
// End: