d5c59c123c
[INTERPRETER] * NEW: Change the GB_FUNCTION structure so that it stores the index of the method instead of its description pointer. [GB.DATA] * OPT: The new GB_FUNCTION structure allows to reduce the size of the GRAPH_DESC structure.
66 lines
1.5 KiB
C
66 lines
1.5 KiB
C
/*
|
|
* c_graph.h
|
|
*
|
|
* Copyright (C) 2014 Tobias Boege <tobias@gambas-buch.de>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
* MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef __C_GRAPH_H
|
|
#define __C_GRAPH_H
|
|
|
|
#include "gambas.h"
|
|
|
|
extern GB_INTERFACE GB;
|
|
|
|
typedef struct {
|
|
ushort _getVertex;
|
|
ushort _getEdge;
|
|
|
|
ushort _nextVertex;
|
|
ushort _nextEdge;
|
|
|
|
ushort _countVertices;
|
|
ushort _countEdges;
|
|
|
|
ushort _nextInEdge;
|
|
ushort _nextOutEdge;
|
|
ushort _nextAdjacent;
|
|
|
|
ushort _vertexProperty;
|
|
ushort _edgeProperty;
|
|
|
|
ushort _vertexUnknown;
|
|
ushort _edgeUnknown;
|
|
} GRAPH_DESC;
|
|
|
|
typedef struct {
|
|
GB_BASE ob;
|
|
GRAPH_DESC *desc;
|
|
char *vertex;
|
|
GB_ARRAY edge;
|
|
GB_VARIANT_VALUE tag;
|
|
} CGRAPH;
|
|
|
|
extern GRAPH_DESC *get_desc(void *_object);
|
|
|
|
#ifndef __C_GRAPH_C
|
|
extern GB_DESC CGraph[], CGraphVertices[], CGraphEdges[], CGraphInEdges[],
|
|
CGraphOutEdges[], CGraphAdjacent[], CGraphVertex[],
|
|
CGraphEdge[];
|
|
#endif
|
|
|
|
#endif /* __C_GRAPH_H */
|