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 38 by douglas, 2004-07-22T22:42:40-07:00 vs.
Revision 60 by douglas, 2004-09-15T19:43:29-07:00

# Line 11 | Line 11
11   Publisher::Publisher(const std::set<Buddy>& buddies, const Database& database, bool start) : buddies(buddies),
12          database(database), start(start)
13   {
14 <        if (start) publisher.Spawn(etl::Bind<0>(&Publisher::publish, this));
14 >        if (start) publish();
15   }
16  
17 < int Publisher::publish()
17 > void Publisher::publish()
18   {
19 <        cerr << bright << green << "Started publisher daemon at " << Stamp()
20 <                << ".\n" << reset;
21 <
22 <        while (true)
23 <        {
24 <                Stamp now, next(now + Hour(1));
25 <                api::Thread thread(etl::Bind<0>(&Publisher::update, this));
26 <
27 <                next.setSeconds(0);
28 <                next.setMinutes(0);
29 <
30 <                if (Zoe::debug) cerr << "now = " << now << "\nnext = " << next << '\n';
31 <
32 <                while (now < next - Minute(1))
33 <                {
34 <                        sleep(Minute(1));
35 <
36 <                        now = Stamp();
37 <                }
38 <
39 <                while (now < next)
40 <                {
41 <                        sleep(1);
42 <
43 <                        now = Stamp();
44 <                }
45 <
46 <                thread.Join();
47 <        }
48 < }
49 <
50 < int Publisher::update()
51 < {
52 <        cerr << bright << yellow << "Started updating feeds at " << Stamp()
19 >        api::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,
23 >        ext::Handle<dbi::Driver> driver(dbi::GetDriver(database.driver));
24 >        ext::Handle<dbi::Connection> db(driver->Connect(database.host,
25                  database.user, database.password, database.db));
26  
27 <        db->Execute("DELETE FROM messages WHERE stamp<'" + ext::String(stamp - Day(30)) + "'");
27 >        db->Execute("DELETE FROM messages WHERE stamp<'"
28 >                + ext::String(stamp - Day(30)) + "'");
29  
30          for (std::set<Buddy>::const_iterator buddy(buddies.begin());
31                  buddy != buddies.end(); ++buddy)
32          {
33 <                ext::Handle<dbi::ResultSet> messages(db->Execute("SELECT stamp, message FROM messages WHERE id='"
34 <                        + lexical_cast<ext::String>(buddy->getId()) + "'"));
35 <                std::vector<AwayMessage> messages_;
33 >                ext::Handle<dbi::ResultSet> messages(db->Execute(ios::String()
34 >                        << "SELECT stamp, message FROM messages WHERE id='"
35 >                        << buddy->getId() << "'"));
36 >                std::set<AwayMessage, std::greater<AwayMessage> > messages_;
37  
38 <                while (messages->MoveNext()) messages_.push_back(AwayMessage(messages->GetString("message"),
38 >                while (messages->MoveNext())
39 >                        messages_.insert(AwayMessage(messages->GetString("message"),
40                          messages->GetString("stamp")));
41  
42 <                Rss rss(*buddy, messages_, stamp);
43 <                Atom atom(*buddy, messages_, stamp);
42 >                ext::String display(buddy->getDisplay(database));
43 >                Rss rss(*buddy, display, messages_.begin(), messages_.end(), stamp);
44 >                Atom atom(*buddy, display, messages_.begin(), messages_.end(), stamp);
45  
46 <                cerr << bright << yellow << "Updated feeds for " << blue << *buddy
46 >                api::Cerr << bright << yellow << "Updated feeds for " << blue << *buddy
47                          << yellow << ".\n" << reset;
48          }
49  
50 <        cerr << bright << yellow << "Finished updating feeds at " << Stamp()
50 >        api::Cerr << bright << yellow << "Finished updating feeds at " << Stamp()
51                  << ".\n" << reset;
52   }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines