2010-10-27 07:03:58 -05:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2003-10-15 08:44:37 -05:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2010-02-12 08:01:35 -06:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* This file is part of OpenOffice.org.
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* OpenOffice.org 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 Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
2008-04-10 06:13:45 -05:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2003-10-15 08:44:37 -05:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __NODES_H__
|
|
|
|
#define __NODES_H__
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "list.hxx"
|
|
|
|
|
|
|
|
enum IDLIST {
|
|
|
|
ID_MATHML,
|
|
|
|
ID_LINES,
|
|
|
|
ID_LINE,
|
|
|
|
ID_EXPRLIST,
|
|
|
|
ID_EXPR,
|
|
|
|
ID_BEGIN,
|
|
|
|
ID_END,
|
|
|
|
ID_LEFT,
|
|
|
|
ID_RIGHT,
|
|
|
|
ID_SUBEXPR,
|
|
|
|
ID_SUPEXPR,
|
|
|
|
ID_SUBSUPEXPR,
|
|
|
|
ID_FRACTIONEXPR,
|
|
|
|
ID_OVER,
|
|
|
|
ID_DECORATIONEXPR,
|
|
|
|
ID_SQRTEXPR,
|
|
|
|
ID_ROOTEXPR,
|
|
|
|
ID_ARROWEXPR,
|
|
|
|
ID_ACCENTEXPR,
|
|
|
|
ID_UNARYEXPR,
|
|
|
|
ID_PRIMARYEXPR,
|
|
|
|
ID_BRACKET,
|
|
|
|
ID_BLOCK,
|
|
|
|
ID_PARENTH,
|
|
|
|
ID_FENCE,
|
|
|
|
ID_ABS,
|
|
|
|
ID_IDENTIFIER,
|
|
|
|
ID_STRING,
|
|
|
|
ID_CHARACTER,
|
|
|
|
ID_NUMBER,
|
|
|
|
ID_OPERATOR,
|
|
|
|
ID_SPACE,
|
|
|
|
ID_DELIMETER
|
|
|
|
};
|
|
|
|
|
|
|
|
class Node{
|
|
|
|
public:
|
|
|
|
Node(int _id) : id(_id)
|
|
|
|
{
|
|
|
|
value = 0L;
|
|
|
|
child = 0L;
|
|
|
|
next = 0L;
|
|
|
|
#ifdef NODE_DEBUG
|
|
|
|
count++;
|
|
|
|
printf("Node count : [%d]\n",count);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
~Node()
|
|
|
|
{
|
|
|
|
if( value ) free( value );
|
|
|
|
// if( child ) delete child;
|
|
|
|
// if( next ) delete next;
|
|
|
|
next = 0L;
|
|
|
|
child = 0L;
|
|
|
|
#ifdef NODE_DEBUG
|
|
|
|
count--;
|
|
|
|
printf("Node count : [%d]\n",count);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
void print(){
|
|
|
|
}
|
|
|
|
public:
|
|
|
|
static int count; /* For memory debugging */
|
|
|
|
int id;
|
|
|
|
char *value;
|
|
|
|
Node *child;
|
|
|
|
Node *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
//static LinkedList<Node> nodelist;
|
|
|
|
|
|
|
|
#endif
|
2010-10-27 07:03:58 -05:00
|
|
|
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|