/* * Copyright (C) 2008 Emweb bvba, Heverlee, Belgium. * * See the LICENSE file for terms of use. */ #include #include #include #include #include #include #include // c++0x only, for std::bind // #include using namespace Wt; /* * A simple hello world application class which demonstrates how to react * to events, read input, and give feed-back. */ class HelloApplication : public WApplication { public: HelloApplication(const WEnvironment& env); private: WLineEdit *nameEdit_; WText *greeting_; void greet(); }; /* * The env argument contains information about the new session, and * the initial request. It must be passed to the WApplication * constructor so it is typically also an argument for your custom * application constructor. */ HelloApplication::HelloApplication(const WEnvironment& env) : WApplication(env) { setTitle("Hello world"); // application title #if 0 root()->addWidget(new WText("Your name, please ? ")); // show some text nameEdit_ = new WLineEdit(root()); // allow text input nameEdit_->setFocus(); // give focus WPushButton *button = new WPushButton("Greet me.", root()); // create a button button->setMargin(5, Left); // add 5 pixels margin root()->addWidget(new WBreak()); // insert a line break greeting_ = new WText(root()); // empty text /* * Connect signals with slots * * - simple Wt-way */ button->clicked().connect(this, &HelloApplication::greet); /* * - using an arbitrary function object (binding values with boost::bind()) */ nameEdit_->enterPressed().connect (boost::bind(&HelloApplication::greet, this)); #endif //typedef Base *(*CreatePlugin)(); // create a function pointer type that points to CreatePlugin typedef void ( __cdecl* PFLOADDELIBERY )(void*); HINSTANCE hinst= LoadLibrary("Test.dll"); if ( NULL == hinst ) { return; } PFLOADDELIBERY pLoadDelivery = (PFLOADDELIBERY)GetProcAddress ( hinst, "LoadUINoWork" ); pLoadDelivery((void*)root()); /* * - using a c++0x lambda: */ // b->clicked().connect(std::bind([=]() { // greeting_->setText("Hello there, " + nameEdit_->text()); // })); } void HelloApplication::greet() { /* * Update the text, using text input into the nameEdit_ field. */ greeting_->setText("Hello there, " + nameEdit_->text()); } WApplication *createApplication(const WEnvironment& env) { /* * You could read information from the environment to decide whether * the user has permission to start a new application */ return new HelloApplication(env); } int main(int argc, char **argv) { /* * Your main method may set up some shared resources, but should then * start the server application (FastCGI or httpd) that starts listening * for requests, and handles all of the application life cycles. * * The last argument to WRun specifies the function that will instantiate * new application objects. That function is executed when a new user surfs * to the Wt application, and after the library has negotiated browser * support. The function should return a newly instantiated application * object. */ return WRun(argc, argv, &createApplication); }