All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Utils.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/vp/qt/Utils.cpp
22 
23  \brief Utility functions for Vector Processing.
24 */
25 
26 // TerraLib
27 #include "../../dataaccess/datasource/DataSourceInfo.h"
28 #include "../../dataaccess/datasource/DataSourceManager.h"
29 #include "../../dataaccess/utils/Utils.h"
30 #include "../../geometry/Geometry.h"
31 #include "../../geometry/GeometryCollection.h"
32 #include "../../geometry/GeometryProperty.h"
33 #include "../../memory/DataSet.h"
34 #include "Utils.h"
35 
36 // Qt
37 #include <QTreeView>
38 
39 //STL
40 #include <memory>
41 #include <vector>
42 
43 // Boost
44 #include <boost/algorithm/string.hpp>
45 
46 std::list<te::map::AbstractLayerPtr> te::vp::GetFilteredLayers(std::string text, std::list<te::map::AbstractLayerPtr> layers)
47 {
48  std::list<te::map::AbstractLayerPtr> filteredList;
49 
50  for(std::list<te::map::AbstractLayerPtr>::iterator it = layers.begin(); it != layers.end(); ++it)
51  {
52  std::string layName = (*it)->getTitle().substr(0, text.size());
53 
54  if(boost::to_upper_copy(layName) == boost::to_upper_copy(text))
55  filteredList.push_back(*it);
56  }
57 
58  return filteredList;
59 }
Utility functions for the data access module.
std::list< te::map::AbstractLayerPtr > GetFilteredLayers(std::string text, std::list< te::map::AbstractLayerPtr > layers)
Get a list of AbstractLayer filtered by the name;.
Definition: Utils.cpp:46