MBDyn-1.7.3
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups
search.h
Go to the documentation of this file.
1 /* $Header: /var/cvs/mbdyn/mbdyn/mbdyn-1.0/libraries/libmbutil/search.h,v 1.17 2017/01/12 14:44:05 masarati Exp $ */
2 /*
3  * MBDyn (C) is a multibody analysis code.
4  * http://www.mbdyn.org
5  *
6  * Copyright (C) 1996-2017
7  *
8  * Pierangelo Masarati <masarati@aero.polimi.it>
9  * Paolo Mantegazza <mantegazza@aero.polimi.it>
10  *
11  * Dipartimento di Ingegneria Aerospaziale - Politecnico di Milano
12  * via La Masa, 34 - 20156 Milano, Italy
13  * http://www.aero.polimi.it
14  *
15  * Changing this copyright notice is forbidden.
16  *
17  * This program is free software; you can redistribute it and/or modify
18  * it under the terms of the GNU General Public License as published by
19  * the Free Software Foundation (version 2 of the License).
20  *
21  *
22  * This program is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25  * GNU General Public License for more details.
26  *
27  * You should have received a copy of the GNU General Public License
28  * along with this program; if not, write to the Free Software
29  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
30  */
31 
32 /* funzione di ricerca di oggetti dotati di label,
33  * basati sulla classe WithLabel */
34 
35 
36 
37 /* include per il debug */
38 #include "myassert.h"
39 
40 
41 /* include del programma */
42 #include "withlab.h"
43 
44 /*
45 extern WithLabel* pLabelSearch(WithLabel** const p, int iSize, unsigned int uL);
46 extern int LabelSearch(WithLabel** const p, int iSize, unsigned int uL);
47 */
48 
49 template <class T>
50 T* pLabelSearch(T** const p, int iSize, unsigned int uL)
51 {
52  ASSERT(p != NULL);
53  for (int i = 0; i < iSize; i++) {
54  if (p[i] != NULL && p[i]->GetLabel() == uL) {
55  return p[i];
56  }
57  }
58  return NULL;
59 }
60 
61 template <class T>
62 int LabelSearch(T** const p, int iSize, unsigned int uL)
63 {
64  ASSERT(p != NULL);
65  for (int i = 0; i < iSize; i++) {
66  if (p[i] != NULL && p[i]->GetLabel() == uL) {
67  return i;
68  }
69  }
70  return -1;
71 }
72 
73 
T * pLabelSearch(T **const p, int iSize, unsigned int uL)
Definition: search.h:50
#define ASSERT(expression)
Definition: colamd.c:977
int LabelSearch(T **const p, int iSize, unsigned int uL)
Definition: search.h:62