File: tutorial.cpp

package info (click to toggle)
boost1.35 1.35.0-5
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 203,856 kB
  • ctags: 337,867
  • sloc: cpp: 938,683; xml: 56,847; ansic: 41,589; python: 18,999; sh: 11,566; makefile: 664; perl: 494; yacc: 456; asm: 353; csh: 6
file content (38 lines) | stat: -rw-r--r-- 1,190 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// Copyright David Abrahams 2005. Distributed under the Boost
// Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

#include <iostream>
#include <boost/parameter/keyword.hpp>

namespace graphs
{
   BOOST_PARAMETER_KEYWORD(tag, graph)    // Note: no semicolon
   BOOST_PARAMETER_KEYWORD(tag, visitor)
   BOOST_PARAMETER_KEYWORD(tag, root_vertex)
   BOOST_PARAMETER_KEYWORD(tag, index_map)
   BOOST_PARAMETER_KEYWORD(tag, color_map)
}

namespace graphs { namespace core
{
   template <class ArgumentPack>
   void depth_first_search(ArgumentPack const& args)
   {
       std::cout << "graph:\t" << args[graph] << std::endl;
       std::cout << "visitor:\t" << args[visitor] << std::endl;
       std::cout << "root_vertex:\t" << args[root_vertex] << std::endl;
       std::cout << "index_map:\t" << args[index_map] << std::endl;
       std::cout << "color_map:\t" << args[color_map] << std::endl;
   }
}} // graphs::core

int main()
{
     using namespace graphs;

     core::depth_first_search((
       graph = 'G', visitor = 2, root_vertex = 3.5,
       index_map = "hello, world", color_map = false));
     return 0;
}