File: tutorial.cpp

package info (click to toggle)
boost1.42 1.42.0-4
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 277,864 kB
  • ctags: 401,076
  • sloc: cpp: 1,235,659; xml: 74,142; ansic: 41,313; python: 26,756; sh: 11,840; cs: 2,118; makefile: 655; 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;
}