ViewVC Help
View File | Revision Log | Show Annotations | Download File | View Changeset | Root Listing
root/zoe/trunk/Publisher.cpp
(Generate patch)

Comparing trunk/Publisher.cpp (file contents):
Revision 31 by douglas, 2004-07-20T00:11:56-07:00 vs.
Revision 43 by douglas, 2004-08-15T21:33:25-07:00

# Line 6 | Line 6
6  
7   #include "Publisher.hpp"
8   #include "Rss.hpp"
9 + #include "Atom.hpp"
10  
11 < Publisher::Publisher(const std::set<Buddy>& buddies, const Database& database,
12 <        bool start) : buddies(buddies), database(database), start(start)
11 > Publisher::Publisher(const std::set<Buddy>& buddies, const Database& database, bool start) : buddies(buddies),
12 >        database(database), start(start)
13   {
14 <        if (start)
14 <        {
15 <                publisher.Spawn(etl::Bind<0>(&Publisher::publish, this));
16 <        }
14 >        if (start) publish();
15   }
16  
17 < int Publisher::publish()
17 > void Publisher::publish()
18   {
19 <        cerr << bright << green << "Publisher::publish()\n" << reset;
20 <
23 <        // publish
24 <
25 <        while (true)
26 <        {
27 <                Stamp start, now;
28 <
29 <                update();
30 <
31 <                do
32 <                {
33 <                        sleep(Minute(1));
34 <
35 <                        now = Stamp();
36 <
37 <                        cerr << bright << magenta << ext::String(now) << white << '<'
38 <                                << cyan << ext::String(start + Hour(1)) << '\n' << reset;
39 <                }
40 <                while (now < start + Hour(1));
41 <        }
42 < }
43 <
44 < void Publisher::update()
45 < {
46 <        cerr << bright << yellow << "Publisher::update()\n" << reset;
19 >        cerr << bright << yellow << "Started updating feeds at " << Stamp()
20 >                << ".\n" << reset;
21  
22          Stamp stamp;
23          ext::Handle<dbi::Connection> db(dbi::Connect(database.driver, database.host,
24                  database.user, database.password, database.db));
25  
26 <        db->Execute("DELETE FROM messages WHERE stamp<'" + (stamp - Day(30)) + "'");
26 >        db->Execute("DELETE FROM messages WHERE stamp<'" + ext::String(stamp - Day(30)) + "'");
27  
28 <        for (std::set<Buddy>::const_iterator buddy(buddies.begin()); buddy !=
29 <                buddies.end(); ++buddy)
28 >        for (std::set<Buddy>::const_iterator buddy(buddies.begin());
29 >                buddy != buddies.end(); ++buddy)
30          {
31 <                ext::Handle<dbi::ResultSet> messages(db->Execute(ext::String("SELECT s")
32 <                        + "tamp, message FROM messages WHERE id='" +
59 <                        lexical_cast<ext::String>(buddy->getId()) + "'"));
31 >                ext::Handle<dbi::ResultSet> messages(db->Execute("SELECT stamp, message FROM messages WHERE id='"
32 >                        + lexical_cast<ext::String>(buddy->getId()) + "'"));
33                  std::vector<AwayMessage> messages_;
34  
35 <                while (messages->MoveNext())
63 <                        messages_.push_back(AwayMessage(messages->GetString("message"),
35 >                while (messages->MoveNext()) messages_.push_back(AwayMessage(messages->GetString("message"),
36                          messages->GetString("stamp")));
37  
38                  Rss rss(*buddy, messages_, stamp);
39 +                Atom atom(*buddy, messages_, stamp);
40 +
41 +                cerr << bright << yellow << "Updated feeds for " << blue << *buddy
42 +                        << yellow << ".\n" << reset;
43          }
44 +
45 +        cerr << bright << yellow << "Finished updating feeds at " << Stamp()
46 +                << ".\n" << reset;
47   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines