Files correlati : Commento : Spostamento in libraries delle librerie esterne di Campo per una maggiore pulizia e organizzazione git-svn-id: svn://10.65.10.50/branches/R_10_00@24150 c028cbd2-c16b-5b4b-a496-9718f37d4682
172 lines
5.3 KiB
C++
172 lines
5.3 KiB
C++
/*
|
|
* Copyright (c) <2002-2005> <Jean-Philippe Barrette-LaPierre>
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining
|
|
* a copy of this software and associated documentation files
|
|
* (curlpp), to deal in the Software without restriction,
|
|
* including without limitation the rights to use, copy, modify, merge,
|
|
* publish, distribute, sublicense, and/or sell copies of the Software,
|
|
* and to permit persons to whom the Software is furnished to do so,
|
|
* subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included
|
|
* in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
|
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
/**
|
|
* \file
|
|
* Setting and copying options.
|
|
*
|
|
*/
|
|
|
|
|
|
#include <string>
|
|
#include <sstream>
|
|
#include <iostream>
|
|
|
|
#include <curlpp/cURLpp.hpp>
|
|
#include <curlpp/Easy.hpp>
|
|
#include <curlpp/Options.hpp>
|
|
|
|
|
|
namespace
|
|
{
|
|
const long MyPort = 80;
|
|
}
|
|
|
|
/**
|
|
* This example is made to show you how you can use the Options.
|
|
*/
|
|
int main(int, char **)
|
|
{
|
|
try
|
|
{
|
|
curlpp::Cleanup myCleanup;
|
|
|
|
// First easy example.
|
|
{
|
|
// The first easiest example is to retreive the content of
|
|
// a web page and put it in a stream.
|
|
std::cout << curlpp::options::Url("http://example.com");
|
|
|
|
// You don't need to use just the standard outputs. You
|
|
// can use any stream:
|
|
std::ostringstream os;
|
|
os << curlpp::options::Url("http://example.com");
|
|
}
|
|
|
|
// More elaborate example.
|
|
{
|
|
// What the previous example done there was simply
|
|
// to create a curlpp::Easy class, which is the basic
|
|
// object in cURLpp, and then set the Url option.
|
|
// curlpp::options classes are the primitives that allow to specify
|
|
// values to the requests.
|
|
curlpp::options::Url myUrl(std::string("http://example.com"));
|
|
curlpp::Easy myRequest;
|
|
myRequest.setOpt(myUrl);
|
|
|
|
// Now that all the options we wanted to set are there, we need to
|
|
// actually do the request. the "perform" method does actually that.
|
|
// With that call, the request will be done and the content of that URL
|
|
// will be printed in std::cout (which is the default).
|
|
myRequest.perform();
|
|
|
|
// If we wanted to put the content of the URL within a string stream
|
|
// (or any type of std::ostream, for that matter), like the first example,
|
|
// we would use the WriteStrem option like this:
|
|
std::ostringstream os;
|
|
curlpp::options::WriteStream ws(&os);
|
|
myRequest.setOpt(ws);
|
|
myRequest.perform();
|
|
|
|
// There is some shorcut within curlpp that allow you to write shorter code
|
|
// like this:
|
|
os << myRequest;
|
|
|
|
// That would do exactly what the previous code was doing.
|
|
}
|
|
|
|
// Creation of the URL option.
|
|
curlpp::options::Url myUrl(std::string("http://example.com"));
|
|
|
|
// Copy construct from the other URL.
|
|
curlpp::options::Url myUrl2(myUrl);
|
|
|
|
// Creation of the port option.
|
|
curlpp::options::Port myPort(MyPort);
|
|
|
|
// Creation of the request.
|
|
curlpp::Easy myRequest;
|
|
|
|
// Creation of an option that contain a copy of the URL option.
|
|
curlpp::OptionBase *mytest = myUrl.clone();
|
|
myRequest.setOpt(*mytest);
|
|
|
|
// You can reuse the base option for other type of option
|
|
// and set the option to the request. but first, don't forget
|
|
// to delete the previous memory. You can delete it since the
|
|
// option is internally duplicated for the request.
|
|
delete mytest;
|
|
mytest = myPort.clone();
|
|
myRequest.setOpt(*mytest);
|
|
delete mytest;
|
|
|
|
// You can clone an option directly to the same type of
|
|
// option.
|
|
curlpp::options::Url *myUrl3 = myUrl.clone();
|
|
myRequest.setOpt(myUrl3);
|
|
// Now myUrl3 is owned by the request we will NOT use
|
|
// it anymore.
|
|
|
|
|
|
// You don't need to declare an option if you just want
|
|
// to use it once.
|
|
myRequest.setOpt(curlpp::options::Url("example.com"));
|
|
|
|
|
|
// Note that the previous line wasn't really efficient
|
|
// because we create the option, this option is duplicated
|
|
// for the request and then the option destructor is called.
|
|
// You can use this instead:
|
|
myRequest.setOpt(new curlpp::options::Url("example.com"));
|
|
// Note that with this the request will use directly this
|
|
// instance we just created. Be aware that if you pass an
|
|
// Option pointer to the setOpt function, it will consider
|
|
// the instance has its own instance. The Option instance
|
|
// will be deleted when the request will be deleted, so
|
|
// don't use the instance further in your code.
|
|
|
|
|
|
// Doing the previous line is efficient as this:
|
|
myRequest.setOpt(myUrl.clone());
|
|
|
|
|
|
// You can retreive the value of a specific option.
|
|
std::cout << myUrl2.getValue() << std::endl;
|
|
|
|
// Perform the transaction with the options set.
|
|
myRequest.perform();
|
|
}
|
|
|
|
catch( curlpp::RuntimeError &e )
|
|
{
|
|
std::cout << e.what() << std::endl;
|
|
}
|
|
|
|
catch( curlpp::LogicError &e )
|
|
{
|
|
std::cout << e.what() << std::endl;
|
|
}
|
|
|
|
return 0;
|
|
}
|