From 6d953de53ac706b7d77336592b3959dec70f486e Mon Sep 17 00:00:00 2001 From: David Rose Date: Thu, 7 Aug 2008 17:26:39 +0000 Subject: [PATCH] asynchronous animation binding --- panda/src/chan/Sources.pp | 16 +- panda/src/chan/animBundleNode.cxx | 32 + panda/src/chan/animBundleNode.h | 2 + panda/src/chan/animControl.I | 65 + panda/src/chan/animControl.cxx | 97 +- panda/src/chan/animControl.h | 40 +- panda/src/chan/animPreloadTable.I | 86 + panda/src/chan/animPreloadTable.cxx | 240 + panda/src/chan/animPreloadTable.h | 117 + panda/src/chan/bindAnimRequest.I | 32 + panda/src/chan/bindAnimRequest.cxx | 63 + panda/src/chan/bindAnimRequest.h | 70 + panda/src/chan/chan_composite2.cxx | 2 + panda/src/chan/config_chan.cxx | 12 + panda/src/chan/config_chan.h | 1 + panda/src/chan/movingPart.I | 6 +- panda/src/chan/movingPartBase.cxx | 7 +- panda/src/chan/movingPartMatrix.cxx | 48 +- panda/src/chan/movingPartScalar.cxx | 24 +- panda/src/chan/partBundle.I | 46 + panda/src/chan/partBundle.cxx | 216 +- panda/src/chan/partBundle.h | 21 + panda/src/chan/partGroup.cxx | 2 + panda/src/char/character.cxx | 6 +- panda/src/egg/Sources.pp | 9 +- panda/src/egg/config_egg.cxx | 2 + panda/src/egg/eggAnimPreload.I | 145 + panda/src/egg/eggAnimPreload.cxx | 45 + panda/src/egg/eggAnimPreload.h | 71 + panda/src/egg/egg_composite1.cxx | 1 + panda/src/egg/lexer.cxx.prebuilt | 5996 +++++++++++++------------ panda/src/egg/lexer.lxx | 4 + panda/src/egg/parser.cxx.prebuilt | 6015 +++++++++++--------------- panda/src/egg/parser.h.prebuilt | 319 +- panda/src/egg/parser.yxx | 51 +- panda/src/egg2pg/characterMaker.cxx | 24 + panda/src/event/eventQueue.cxx | 5 + panda/src/event/throw_event.I | 14 + panda/src/event/throw_event.h | 5 + panda/src/pgraph/billboardEffect.cxx | 5 + panda/src/putil/bam.h | 1 + panda/src/putil/bamReader.cxx | 2 + 42 files changed, 7191 insertions(+), 6774 deletions(-) create mode 100644 panda/src/chan/animPreloadTable.I create mode 100644 panda/src/chan/animPreloadTable.cxx create mode 100644 panda/src/chan/animPreloadTable.h create mode 100644 panda/src/chan/bindAnimRequest.I create mode 100644 panda/src/chan/bindAnimRequest.cxx create mode 100644 panda/src/chan/bindAnimRequest.h create mode 100644 panda/src/egg/eggAnimPreload.I create mode 100644 panda/src/egg/eggAnimPreload.cxx create mode 100644 panda/src/egg/eggAnimPreload.h diff --git a/panda/src/chan/Sources.pp b/panda/src/chan/Sources.pp index 1fc088b628..8ff7710572 100644 --- a/panda/src/chan/Sources.pp +++ b/panda/src/chan/Sources.pp @@ -20,7 +20,10 @@ animChannelScalarTable.I animChannelScalarTable.h \ animControl.I animControl.N \ animControl.h animControlCollection.I \ - animControlCollection.h animGroup.I animGroup.h auto_bind.h \ + animControlCollection.h animGroup.I animGroup.h \ + animPreloadTable.I animPreloadTable.h \ + auto_bind.h \ + bindAnimRequest.I bindAnimRequest.h \ config_chan.h \ movingPart.I movingPart.h \ movingPartBase.I movingPartBase.h \ @@ -43,7 +46,10 @@ animChannelScalarDynamic.cxx \ animChannelScalarTable.cxx \ animControl.cxx \ - animControlCollection.cxx animGroup.cxx auto_bind.cxx \ + animControlCollection.cxx animGroup.cxx \ + animPreloadTable.cxx \ + auto_bind.cxx \ + bindAnimRequest.cxx \ config_chan.cxx movingPartBase.cxx movingPartMatrix.cxx \ movingPartScalar.cxx partBundle.cxx \ partBundleHandle.cxx \ @@ -64,7 +70,11 @@ animChannelScalarTable.I animChannelScalarTable.h \ animControl.I animControl.h \ animControlCollection.I animControlCollection.h animGroup.I \ - animGroup.h auto_bind.h config_chan.h \ + animGroup.h \ + animPreloadTable.I animPreloadTable.h \ + auto_bind.h \ + bindAnimRequest.I bindAnimRequest.h \ + config_chan.h \ movingPart.I movingPart.h movingPartBase.I \ movingPartBase.h movingPartMatrix.I movingPartMatrix.h \ movingPartScalar.I movingPartScalar.h partBundle.I partBundle.h \ diff --git a/panda/src/chan/animBundleNode.cxx b/panda/src/chan/animBundleNode.cxx index 5cd374cddb..a74dd8d343 100644 --- a/panda/src/chan/animBundleNode.cxx +++ b/panda/src/chan/animBundleNode.cxx @@ -45,6 +45,38 @@ safe_to_flatten() const { return false; } +//////////////////////////////////////////////////////////////////// +// Function: AnimBundleNode::find_anim_bundle +// Access: Published, Static +// Description: Recursively walks the scene graph beginning at the +// indicated node (which need not be an AnimBundleNode), +// and returns the first AnimBundle found. Returns NULL +// if no AnimBundle can be found. +//////////////////////////////////////////////////////////////////// +AnimBundle *AnimBundleNode:: +find_anim_bundle(PandaNode *root) { + nassertr(root != (PandaNode *)NULL, NULL); + + if (root->is_of_type(AnimBundleNode::get_class_type())) { + AnimBundleNode *anode = DCAST(AnimBundleNode, root); + AnimBundle *anim = anode->get_bundle(); + if (anim != (AnimBundle *)NULL) { + return anim; + } + } + + Children cr = root->get_children(); + int num_children = cr.get_num_children(); + for (int i = 0; i < num_children; i++) { + AnimBundle *anim = find_anim_bundle(cr.get_child(i)); + if (anim != (AnimBundle *)NULL) { + return anim; + } + } + + return NULL; +} + //////////////////////////////////////////////////////////////////// // Function: AnimBundleNode::register_with_read_factory // Access: Public, Static diff --git a/panda/src/chan/animBundleNode.h b/panda/src/chan/animBundleNode.h index 8071227db7..946af0d59a 100644 --- a/panda/src/chan/animBundleNode.h +++ b/panda/src/chan/animBundleNode.h @@ -42,6 +42,8 @@ public: PUBLISHED: INLINE AnimBundle *get_bundle() const; + + static AnimBundle *find_anim_bundle(PandaNode *root); private: PT(AnimBundle) _bundle; diff --git a/panda/src/chan/animControl.I b/panda/src/chan/animControl.I index b9d541ae97..963b733674 100644 --- a/panda/src/chan/animControl.I +++ b/panda/src/chan/animControl.I @@ -13,6 +13,33 @@ //////////////////////////////////////////////////////////////////// +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::is_pending +// Access: Published +// Description: Returns true if the AnimControl is being bound +// asynchronously, and has not yet finished. If this is +// true, the AnimControl's interface is still available +// and will be perfectly useful (though get_anim() might +// return NULL), but nothing visible will happen +// immediately. +//////////////////////////////////////////////////////////////////// +INLINE bool AnimControl:: +is_pending() const { + return _pending; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::has_anim +// Access: Published +// Description: Returns true if the AnimControl was successfully +// loaded, or false if there was a problem. This may +// return false while is_pending() is true. +//////////////////////////////////////////////////////////////////// +INLINE bool AnimControl:: +has_anim() const { + return (_anim != (AnimBundle *)NULL); +} + //////////////////////////////////////////////////////////////////// // Function: AnimControl::get_anim // Access: Published @@ -56,3 +83,41 @@ INLINE const BitArray &AnimControl:: get_bound_joints() const { return _bound_joints; } + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::set_anim_model +// Access: Published +// Description: Associates the indicated PandaNode with the +// AnimControl. By convention, this node represents the +// root node of the model file that corresponds to this +// AnimControl's animation file, though nothing in this +// code makes this assumption or indeed does anything +// with this node. +// +// The purpose of this is simply to allow the +// AnimControl to keep a reference count on the +// ModelRoot node that generated it, so that the model +// will not disappear from the model pool until it is no +// longer referenced. +//////////////////////////////////////////////////////////////////// +INLINE void AnimControl:: +set_anim_model(PandaNode *model) { + _anim_model = model; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::get_anim_model +// Access: Published +// Description: Retrieves the pointer set via set_anim_model(). See +// set_anim_model(). +//////////////////////////////////////////////////////////////////// +INLINE PandaNode *AnimControl:: +get_anim_model() const { + return _anim_model; +} + +INLINE ostream & +operator << (ostream &out, const AnimControl &control) { + control.output(out); + return out; +} diff --git a/panda/src/chan/animControl.cxx b/panda/src/chan/animControl.cxx index e7efbe2971..4f7745dd69 100644 --- a/panda/src/chan/animControl.cxx +++ b/panda/src/chan/animControl.cxx @@ -17,29 +17,81 @@ #include "partBundle.h" #include "config_chan.h" #include "dcast.h" +#include "mutexHolder.h" +#include "throw_event.h" TypeHandle AnimControl::_type_handle; //////////////////////////////////////////////////////////////////// // Function: AnimControl::Constructor // Access: Public -// Description: +// Description: This constructor is used to create a temporarily +// uninitialized AnimControl that will serve as a +// placeholder for an animation while the animation is +// being loaded during an asynchronous load-and-bind +// operation. //////////////////////////////////////////////////////////////////// AnimControl:: -AnimControl(PartBundle *part, AnimBundle *anim, int channel_index, - const BitArray &bound_joints) { +AnimControl(const string &name, PartBundle *part, + double frame_rate, int num_frames) : + Namable(name) +{ #ifdef DO_MEMORY_USAGE MemoryUsage::update_type(this, get_class_type()); #endif + _pending = true; _part = part; + _anim = NULL; + _channel_index = -1; + set_frame_rate(frame_rate); + set_num_frames(num_frames); + + _marked_frame = -1; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::setup_anim +// Access: Public +// Description: This can only be called once for a given AnimControl. +// It is used to supply the AnimBundle and related +// information. +//////////////////////////////////////////////////////////////////// +void AnimControl:: +setup_anim(PartBundle *part, AnimBundle *anim, int channel_index, + const BitArray &bound_joints) { + MutexHolder holder(_pending_lock); + nassertv(_pending && part == _part); + nassertv(_anim == (AnimBundle *)NULL); _anim = anim; _channel_index = channel_index; _bound_joints = bound_joints; set_frame_rate(_anim->get_base_frame_rate()); set_num_frames(_anim->get_num_frames()); + // Now the AnimControl is fully set up. _marked_frame = -1; + _pending = false; + if (!_pending_done_event.empty()) { + throw_event(_pending_done_event); + } +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::fail_anim +// Access: Public +// Description: This can only be called once for a given AnimControl. +// It indicates the attempt to bind it asynchronously +// has failed. +//////////////////////////////////////////////////////////////////// +void AnimControl:: +fail_anim(PartBundle *part) { + MutexHolder holder(_pending_lock); + nassertv(_pending && part == _part); + _pending = false; + if (!_pending_done_event.empty()) { + throw_event(_pending_done_event); + } } //////////////////////////////////////////////////////////////////// @@ -52,6 +104,35 @@ AnimControl:: get_part()->set_control_effect(this, 0.0f); } +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::set_pending_done_event +// Access: Published +// Description: Specifies an event name that will be thrown when the +// AnimControl is finished binding asynchronously. If +// the AnimControl has already finished binding, the +// event will be thrown immediately. +//////////////////////////////////////////////////////////////////// +void AnimControl:: +set_pending_done_event(const string &done_event) { + MutexHolder holder(_pending_lock); + _pending_done_event = done_event; + if (!_pending) { + throw_event(_pending_done_event); + } +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimControl::get_pending_done_event +// Access: Published +// Description: Returns the event name that will be thrown when the +// AnimControl is finished binding asynchronously. +//////////////////////////////////////////////////////////////////// +string AnimControl:: +get_pending_done_event() const { + MutexHolder holder(_pending_lock); + return _pending_done_event; +} + //////////////////////////////////////////////////////////////////// // Function: AnimControl::get_part // Access: Published @@ -70,10 +151,16 @@ get_part() const { //////////////////////////////////////////////////////////////////// void AnimControl:: output(ostream &out) const { - out << "AnimControl(" << get_part()->get_name() - << ", " << get_anim()->get_name() << ": "; + out << "AnimControl(" << get_name() << ", " << get_part()->get_name() + << ": "; AnimInterface::output(out); out << ")"; + + if (is_pending()) { + out << " (pending bind)"; + } else if (!has_anim()) { + out << " (failed bind)"; + } } //////////////////////////////////////////////////////////////////// diff --git a/panda/src/chan/animControl.h b/panda/src/chan/animControl.h index 3f1e30ca1b..643dd0a6fc 100644 --- a/panda/src/chan/animControl.h +++ b/panda/src/chan/animControl.h @@ -21,8 +21,10 @@ #include "animBundle.h" #include "partGroup.h" #include "bitArray.h" - -#include "referenceCount.h" +#include "pandaNode.h" +#include "typedReferenceCount.h" +#include "namable.h" +#include "pmutex.h" class PartBundle; class AnimChannelBase; @@ -35,19 +37,30 @@ class AnimChannelBase; // animation: whether started, stopped, or looping, and // the current frame number and play rate. //////////////////////////////////////////////////////////////////// -class EXPCL_PANDA_CHAN AnimControl : public ReferenceCount, public AnimInterface { +class EXPCL_PANDA_CHAN AnimControl : public TypedReferenceCount, public AnimInterface, public Namable { public: - AnimControl(PartBundle *part, AnimBundle *anim, int channel_index, - const BitArray &bound_joints); + AnimControl(const string &name, PartBundle *part, + double frame_rate, int num_frames); + void setup_anim(PartBundle *part, AnimBundle *anim, int channel_index, + const BitArray &bound_joints); + void fail_anim(PartBundle *part); PUBLISHED: virtual ~AnimControl(); + INLINE bool is_pending() const; + INLINE bool has_anim() const; + void set_pending_done_event(const string &done_event); + string get_pending_done_event() const; + PartBundle *get_part() const; INLINE AnimBundle *get_anim() const; INLINE int get_channel_index() const; INLINE const BitArray &get_bound_joints() const; + INLINE void set_anim_model(PandaNode *model); + INLINE PandaNode *get_anim_model() const; + virtual void output(ostream &out) const; public: @@ -65,6 +78,10 @@ private: // This is a PT(PartGroup) instead of a PT(PartBundle), just because // we can't include partBundle.h for circular reasons. But it // actually keeps a pointer to a PartBundle. + bool _pending; + string _pending_done_event; + Mutex _pending_lock; // protects the above two. + PT(PartGroup) _part; PT(AnimBundle) _anim; int _channel_index; @@ -80,15 +97,22 @@ private: // get_bound_joints(). BitArray _bound_joints; + PT(PandaNode) _anim_model; + public: + virtual TypeHandle get_type() const { + return get_class_type(); + } + virtual TypeHandle force_init_type() {init_type(); return get_class_type();} + static TypeHandle get_class_type() { return _type_handle; } static void init_type() { - ReferenceCount::init_type(); + TypedReferenceCount::init_type(); AnimInterface::init_type(); register_type(_type_handle, "AnimControl", - ReferenceCount::get_class_type(), + TypedReferenceCount::get_class_type(), AnimInterface::get_class_type()); } @@ -96,6 +120,8 @@ private: static TypeHandle _type_handle; }; +INLINE ostream &operator << (ostream &out, const AnimControl &control); + #include "animControl.I" #endif diff --git a/panda/src/chan/animPreloadTable.I b/panda/src/chan/animPreloadTable.I new file mode 100644 index 0000000000..2f429a0316 --- /dev/null +++ b/panda/src/chan/animPreloadTable.I @@ -0,0 +1,86 @@ +// Filename: animPreloadTable.I +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::AnimRecord::Constructor +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE AnimPreloadTable::AnimRecord:: +AnimRecord() { +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::AnimRecord::operator < +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE bool AnimPreloadTable::AnimRecord:: +operator < (const AnimRecord &other) const { + return _basename < other._basename; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::get_basename +// Access: Published +// Description: Returns the basename stored for the nth animation +// record. See find_anim(). +//////////////////////////////////////////////////////////////////// +INLINE string AnimPreloadTable:: +get_basename(int n) const { + nassertr(n >= 0 && n < (int)_anims.size(), string()); + consider_sort(); + return _anims[n]._basename; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::get_base_frame_rate +// Access: Published +// Description: Returns the frame rate stored for the nth animation +// record. +//////////////////////////////////////////////////////////////////// +INLINE float AnimPreloadTable:: +get_base_frame_rate(int n) const { + nassertr(n >= 0 && n < (int)_anims.size(), 0.0f); + consider_sort(); + return _anims[n]._base_frame_rate; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::get_num_frames +// Access: Published +// Description: Returns the number of frames stored for the nth +// animation record. +//////////////////////////////////////////////////////////////////// +INLINE int AnimPreloadTable:: +get_num_frames(int n) const { + nassertr(n >= 0 && n < (int)_anims.size(), 0); + consider_sort(); + return _anims[n]._num_frames; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::consider_sort +// Access: Private +// Description: Ensures the table is kept in alphabetical order by +// basename. +//////////////////////////////////////////////////////////////////// +INLINE void AnimPreloadTable:: +consider_sort() const { + if (_needs_sort) { + ((AnimPreloadTable *)this)->_anims.sort(); + ((AnimPreloadTable *)this)->_needs_sort = false; + } +} diff --git a/panda/src/chan/animPreloadTable.cxx b/panda/src/chan/animPreloadTable.cxx new file mode 100644 index 0000000000..885efbbe31 --- /dev/null +++ b/panda/src/chan/animPreloadTable.cxx @@ -0,0 +1,240 @@ +// Filename: animPreloadTable.cxx +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#include "animPreloadTable.h" + +#include "indent.h" +#include "datagram.h" +#include "datagramIterator.h" +#include "bamReader.h" +#include "bamWriter.h" + +TypeHandle AnimPreloadTable::_type_handle; + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::make_cow_copy +// Access: Protected, Virtual +// Description: Required to implement CopyOnWriteObject. +//////////////////////////////////////////////////////////////////// +PT(CopyOnWriteObject) AnimPreloadTable:: +make_cow_copy() { + return new AnimPreloadTable(*this); +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::Constructor +// Access: Published +// Description: +//////////////////////////////////////////////////////////////////// +AnimPreloadTable:: +AnimPreloadTable() { + _needs_sort = false; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::Destructor +// Access: Published, Virtual +// Description: +//////////////////////////////////////////////////////////////////// +AnimPreloadTable:: +~AnimPreloadTable() { +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::get_num_anims +// Access: Published +// Description: Returns the number of animation records in the table. +//////////////////////////////////////////////////////////////////// +int AnimPreloadTable:: +get_num_anims() const { + return (int)_anims.size(); +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::find_anim +// Access: Published +// Description: Returns the index number in the table of the +// animation record with the indicated name, or -1 if +// the name is not present. By convention, the basename +// is the filename of the egg or bam file, without the +// directory part and without the extension. That is, +// it is Filename::get_basename_wo_extension(). +//////////////////////////////////////////////////////////////////// +int AnimPreloadTable:: +find_anim(const string &basename) const { + consider_sort(); + AnimRecord record; + record._basename = basename; + Anims::const_iterator ai = _anims.find(record); + if (ai != _anims.end()) { + return int(ai - _anims.begin()); + } + return -1; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::clear_anims +// Access: Published +// Description: Removes all animation records from the table. +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +clear_anims() { + _anims.clear(); + _needs_sort = false; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::remove_anim +// Access: Published +// Description: Removes the nth animation records from the table. +// This renumbers indexes for following animations. +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +remove_anim(int n) { + nassertv(n >= 0 && n < (int)_anims.size()); + _anims.erase(_anims.begin() + n); +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::add_anim +// Access: Published +// Description: Adds a new animation record to the table. If there +// is already a record of this name, no operation is +// performed (the original record is unchanged). See +// find_anim(). This will invalidate existing index +// numbers. +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +add_anim(const string &basename, float base_frame_rate, int num_frames) { + AnimRecord record; + record._basename = basename; + record._base_frame_rate = base_frame_rate; + record._num_frames = num_frames; + + _anims.push_back(record); + _needs_sort = true; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::add_anims_from +// Access: Published +// Description: Copies the animation records from the other table +// into this one. If a given record name exists in both +// tables, the record in this one supercedes. +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +add_anims_from(const AnimPreloadTable *other) { + _anims.reserve(_anims.size() + other->_anims.size()); + Anims::const_iterator ai; + for (ai = other->_anims.begin(); ai != other->_anims.end(); ++ai) { + _anims.push_back(*ai); + } + _needs_sort = true; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::output +// Access: Published +// Description: +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +output(ostream &out) const { + out << "AnimPreloadTable, " << _anims.size() << " animation records."; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::write +// Access: Published +// Description: +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +write(ostream &out, int indent_level) const { + indent(out, indent_level) + << "AnimPreloadTable, " << _anims.size() << " animation records:\n"; + consider_sort(); + Anims::const_iterator ai; + for (ai = _anims.begin(); ai != _anims.end(); ++ai) { + const AnimRecord &record = (*ai); + indent(out, indent_level + 2) + << record._basename << ": " << record._num_frames << " frames at " + << record._base_frame_rate << " fps\n"; + } +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::register_with_read_factory +// Access: Public, Static +// Description: Factory method to generate an AnimPreloadTable object +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +register_with_read_factory() { + BamReader::get_factory()->register_factory(get_class_type(), make_from_bam); +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::write_datagram +// Access: Public +// Description: Function to write the important information in +// the particular object to a Datagram +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +write_datagram(BamWriter *manager, Datagram &dg) { + consider_sort(); + + dg.add_uint16(_anims.size()); + Anims::const_iterator ai; + for (ai = _anims.begin(); ai != _anims.end(); ++ai) { + const AnimRecord &record = (*ai); + dg.add_string(record._basename); + dg.add_float32(record._base_frame_rate); + dg.add_int32(record._num_frames); + } +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::make_from_bam +// Access: Protected +// Description: Factory method to generate an AnimPreloadTable object +//////////////////////////////////////////////////////////////////// +TypedWritable *AnimPreloadTable:: +make_from_bam(const FactoryParams ¶ms) { + AnimPreloadTable *me = new AnimPreloadTable; + DatagramIterator scan; + BamReader *manager; + + parse_params(params, scan, manager); + me->fillin(scan, manager); + return me; +} + +//////////////////////////////////////////////////////////////////// +// Function: AnimPreloadTable::fillin +// Access: Protected +// Description: Function that reads out of the datagram (or asks +// manager to read) all of the data that is needed to +// re-create this object and stores it in the appropiate +// place +//////////////////////////////////////////////////////////////////// +void AnimPreloadTable:: +fillin(DatagramIterator &scan, BamReader *manager) { + int num_anims = scan.get_uint16(); + _anims.reserve(num_anims); + for (int i = 0; i < num_anims; ++i) { + AnimRecord record; + record._basename = scan.get_string(); + record._base_frame_rate = scan.get_float32(); + record._num_frames = scan.get_int32(); + _anims.push_back(record); + } +} diff --git a/panda/src/chan/animPreloadTable.h b/panda/src/chan/animPreloadTable.h new file mode 100644 index 0000000000..8289583a1c --- /dev/null +++ b/panda/src/chan/animPreloadTable.h @@ -0,0 +1,117 @@ +// Filename: animPreloadTable.h +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#ifndef ANIMPRELOADTABLE_H +#define ANIMPRELOADTABLE_H + +#include "pandabase.h" +#include "typedWritableReferenceCount.h" +#include "ordered_vector.h" +#include "copyOnWriteObject.h" + +class BamWriter; +class BamReader; +class Datagram; +class DatagramIterator; +class FactoryParams; + +//////////////////////////////////////////////////////////////////// +// Class : AnimPreloadTable +// Description : This table records data about a list of animations +// for a particular model, such as number of frames and +// frame rate. It's used for implementating +// asynchronous binding. +// +// This table is normally built by an offline tool, such +// as egg-optchar. +//////////////////////////////////////////////////////////////////// +class EXPCL_PANDA_CHAN AnimPreloadTable : public CopyOnWriteObject { +public: + class AnimRecord { + public: + INLINE AnimRecord(); + INLINE bool operator < (const AnimRecord &other) const; + + string _basename; + float _base_frame_rate; + int _num_frames; + }; + +protected: + virtual PT(CopyOnWriteObject) make_cow_copy(); + +PUBLISHED: + AnimPreloadTable(); + virtual ~AnimPreloadTable(); + + int get_num_anims() const; + int find_anim(const string &basename) const; + + INLINE string get_basename(int n) const; + INLINE float get_base_frame_rate(int n) const; + INLINE int get_num_frames(int n) const; + + void clear_anims(); + void remove_anim(int n); + void add_anim(const string &basename, float base_frame_rate, int num_frames); + void add_anims_from(const AnimPreloadTable *other); + + virtual void output(ostream &out) const; + virtual void write(ostream &out, int indent_level) const; + +private: + INLINE void consider_sort() const; + +public: + static void register_with_read_factory(); + virtual void write_datagram(BamWriter *manager, Datagram &dg); + static TypedWritable *make_from_bam(const FactoryParams ¶ms); + +protected: + void fillin(DatagramIterator &scan, BamReader *manager); + +private: + typedef ov_set Anims; + Anims _anims; + bool _needs_sort; + +public: + virtual TypeHandle get_type() const { + return get_class_type(); + } + virtual TypeHandle force_init_type() {init_type(); return get_class_type();} + + static TypeHandle get_class_type() { + return _type_handle; + } + static void init_type() { + CopyOnWriteObject::init_type(); + register_type(_type_handle, "AnimPreloadTable", + CopyOnWriteObject::get_class_type()); + } + +private: + static TypeHandle _type_handle; +}; + +inline ostream &operator << (ostream &out, const AnimPreloadTable &anim) { + anim.output(out); + return out; +} + +#include "animPreloadTable.I" + +#endif + + diff --git a/panda/src/chan/bindAnimRequest.I b/panda/src/chan/bindAnimRequest.I new file mode 100644 index 0000000000..9d619a3d1a --- /dev/null +++ b/panda/src/chan/bindAnimRequest.I @@ -0,0 +1,32 @@ +// Filename: bindAnimRequest.I +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////// +// Function: BindAnimRequest::Constructor +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE BindAnimRequest:: +BindAnimRequest(const Filename &filename, const LoaderOptions &options, + AnimControl *control, int hierarchy_match_flags, + const PartSubset &subset) : + ModelLoadRequest(filename, options), + _control(control), + _hierarchy_match_flags(hierarchy_match_flags), + _subset(subset) +{ +} + + diff --git a/panda/src/chan/bindAnimRequest.cxx b/panda/src/chan/bindAnimRequest.cxx new file mode 100644 index 0000000000..0944b24c43 --- /dev/null +++ b/panda/src/chan/bindAnimRequest.cxx @@ -0,0 +1,63 @@ +// Filename: bindAnimRequest.cxx +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#include "bindAnimRequest.h" +#include "animBundleNode.h" +#include "animControl.h" +#include "partBundle.h" + +TypeHandle BindAnimRequest::_type_handle; + +//////////////////////////////////////////////////////////////////// +// Function: BindAnimRequest::do_task +// Access: Protected, Virtual +// Description: Performs the task: that is, loads and binds the +// animation. +//////////////////////////////////////////////////////////////////// +bool BindAnimRequest:: +do_task() { + ModelLoadRequest::do_task(); + + PartBundle *part = _control->get_part(); + + if (_control->get_ref_count() == 1) { + // We're holding the only remaining reference to this AnimControl. + // Therefore, forget the bind attempt; no one cares anyway. + _control->fail_anim(part); + return false; + } + + PT(PandaNode) model = get_model(); + if (model == (PandaNode *)NULL) { + // Couldn't load the file. + _control->fail_anim(part); + return false; + } + _control->set_anim_model(model); + + AnimBundle *anim = AnimBundleNode::find_anim_bundle(model); + if (anim == (AnimBundle *)NULL) { + // No anim bundle. + _control->fail_anim(part); + return false; + } + + if (!part->do_bind_anim(_control, anim, _hierarchy_match_flags, _subset)) { + // Couldn't bind. + _control->fail_anim(part); + return false; + } + + return false; +} diff --git a/panda/src/chan/bindAnimRequest.h b/panda/src/chan/bindAnimRequest.h new file mode 100644 index 0000000000..e2f84382e4 --- /dev/null +++ b/panda/src/chan/bindAnimRequest.h @@ -0,0 +1,70 @@ +// Filename: bindAnimRequest.h +// Created by: drose (05Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#ifndef BINDANIMREQUEST +#define BINDANIMREQUEST + +#include "pandabase.h" + +#include "modelLoadRequest.h" +#include "partSubset.h" + +class AnimControl; + +//////////////////////////////////////////////////////////////////// +// Class : BindAnimRequest +// Description : This class object manages an asynchronous +// load-and-bind animation request, as issued through +// PartBundle::load_bind_anim(). +//////////////////////////////////////////////////////////////////// +class EXPCL_PANDA_PGRAPH BindAnimRequest : public ModelLoadRequest { +public: + ALLOC_DELETED_CHAIN(BindAnimRequest); + +PUBLISHED: + INLINE BindAnimRequest(const Filename &filename, + const LoaderOptions &options, + AnimControl *control, + int hierarchy_match_flags, + const PartSubset &subset); + +protected: + virtual bool do_task(); + +private: + PT(AnimControl) _control; + int _hierarchy_match_flags; + PartSubset _subset; + +public: + static TypeHandle get_class_type() { + return _type_handle; + } + static void init_type() { + ModelLoadRequest::init_type(); + register_type(_type_handle, "BindAnimRequest", + ModelLoadRequest::get_class_type()); + } + virtual TypeHandle get_type() const { + return get_class_type(); + } + virtual TypeHandle force_init_type() {init_type(); return get_class_type();} + +private: + static TypeHandle _type_handle; +}; + +#include "bindAnimRequest.I" + +#endif diff --git a/panda/src/chan/chan_composite2.cxx b/panda/src/chan/chan_composite2.cxx index 0b60ba1c72..8a5c7b6bfe 100644 --- a/panda/src/chan/chan_composite2.cxx +++ b/panda/src/chan/chan_composite2.cxx @@ -1,3 +1,5 @@ +#include "animPreloadTable.cxx" +#include "bindAnimRequest.cxx" #include "config_chan.cxx" #include "movingPartBase.cxx" #include "movingPartMatrix.cxx" diff --git a/panda/src/chan/config_chan.cxx b/panda/src/chan/config_chan.cxx index 8614c86106..421972d352 100644 --- a/panda/src/chan/config_chan.cxx +++ b/panda/src/chan/config_chan.cxx @@ -24,6 +24,8 @@ #include "animChannelScalarDynamic.h" #include "animControl.h" #include "animGroup.h" +#include "animPreloadTable.h" +#include "bindAnimRequest.h" #include "movingPartBase.h" #include "movingPartMatrix.h" #include "movingPartScalar.h" @@ -86,6 +88,13 @@ PRC_DESC("Set this true to interpolate character animations between frames, " "also be changed on a per-character basis with " "PartBundle::set_frame_blend_flag().")); +ConfigVariableBool restore_initial_pose +("restore-initial-pose", true, +PRC_DESC("When this is true, stopping all animations on an Actor causes it " + "to return to its initial, unanimated pose. When false, it retains " + "whatever its last-computed pose was (which may or may not be " + "the unanimated pose).")); + ConfigureFn(config_chan) { AnimBundle::init_type(); @@ -98,6 +107,8 @@ ConfigureFn(config_chan) { AnimChannelScalarDynamic::init_type(); AnimControl::init_type(); AnimGroup::init_type(); + AnimPreloadTable::init_type(); + BindAnimRequest::init_type(); MovingPartBase::init_type(); MovingPartMatrix::init_type(); MovingPartScalar::init_type(); @@ -125,6 +136,7 @@ ConfigureFn(config_chan) { AnimChannelMatrixDynamic::register_with_read_factory(); AnimChannelScalarTable::register_with_read_factory(); AnimChannelScalarDynamic::register_with_read_factory(); + AnimPreloadTable::register_with_read_factory(); } diff --git a/panda/src/chan/config_chan.h b/panda/src/chan/config_chan.h index e76fe95caf..fa7d1b36fb 100644 --- a/panda/src/chan/config_chan.h +++ b/panda/src/chan/config_chan.h @@ -27,5 +27,6 @@ EXPCL_PANDA_CHAN extern ConfigVariableBool compress_channels; EXPCL_PANDA_CHAN extern ConfigVariableInt compress_chan_quality; EXPCL_PANDA_CHAN extern ConfigVariableBool read_compressed_channels; EXPCL_PANDA_CHAN extern ConfigVariableBool interpolate_frames; +EXPCL_PANDA_CHAN extern ConfigVariableBool restore_initial_pose; #endif diff --git a/panda/src/chan/movingPart.I b/panda/src/chan/movingPart.I index adc7247ec5..10bbfa4329 100644 --- a/panda/src/chan/movingPart.I +++ b/panda/src/chan/movingPart.I @@ -116,8 +116,7 @@ output_value(ostream &out) const { //////////////////////////////////////////////////////////////////// template void MovingPart:: -write_datagram(BamWriter *manager, Datagram &me) -{ +write_datagram(BamWriter *manager, Datagram &me) { MovingPartBase::write_datagram(manager, me); SwitchType::write_datagram(me, _value); SwitchType::write_datagram(me, _initial_value); @@ -133,8 +132,7 @@ write_datagram(BamWriter *manager, Datagram &me) //////////////////////////////////////////////////////////////////// template void MovingPart:: -fillin(DatagramIterator& scan, BamReader* manager) -{ +fillin(DatagramIterator &scan, BamReader *manager) { MovingPartBase::fillin(scan, manager); SwitchType::read_datagram(scan, _value); SwitchType::read_datagram(scan, _initial_value); diff --git a/panda/src/chan/movingPartBase.cxx b/panda/src/chan/movingPartBase.cxx index a84eaffaae..4525986764 100644 --- a/panda/src/chan/movingPartBase.cxx +++ b/panda/src/chan/movingPartBase.cxx @@ -143,9 +143,12 @@ do_update(PartBundle *root, const CycleData *root_cdata, PartGroup *parent, !needs_update && bci != cdata->_blend.end(); ++bci) { AnimControl *control = (*bci).first; + + AnimChannelBase *channel = NULL; int channel_index = control->get_channel_index(); - nassertr(channel_index >= 0 && channel_index < (int)_channels.size(), false); - AnimChannelBase *channel = _channels[channel_index]; + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = _channels[channel_index]; + } if (channel != (AnimChannelBase*)NULL) { needs_update = control->channel_has_changed(channel, cdata->_frame_blend_flag); } diff --git a/panda/src/chan/movingPartMatrix.cxx b/panda/src/chan/movingPartMatrix.cxx index 0f2f4d7db1..6a7989256f 100644 --- a/panda/src/chan/movingPartMatrix.cxx +++ b/panda/src/chan/movingPartMatrix.cxx @@ -73,18 +73,24 @@ get_blend_value(const PartBundle *root) { if (cdata->_blend.empty()) { // No channel is bound; supply the default value. - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else if (cdata->_blend.size() == 1 && !cdata->_frame_blend_flag) { // A single value, the normal case. AnimControl *control = (*cdata->_blend.begin()).first; + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel == (ChannelType *)NULL) { // Nothing is actually bound here. - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { channel->get_value(control->get_frame(), _value); @@ -131,7 +137,9 @@ get_blend_value(const PartBundle *root) { } if (net == 0.0f) { - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { _value /= net; } @@ -157,9 +165,11 @@ get_blend_value(const PartBundle *root) { float effect = (*cbi).second; nassertv(effect != 0.0f); + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel != (ChannelType *)NULL) { int frame = control->get_frame(); ValueType v; @@ -195,7 +205,9 @@ get_blend_value(const PartBundle *root) { } if (net == 0.0f) { - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { _value /= net; @@ -226,9 +238,11 @@ get_blend_value(const PartBundle *root) { float effect = (*cbi).second; nassertv(effect != 0.0f); + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel != (ChannelType *)NULL) { int frame = control->get_frame(); LVecBase3f iscale, ihpr, ipos, ishear; @@ -270,7 +284,9 @@ get_blend_value(const PartBundle *root) { } if (net == 0.0f) { - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { scale /= net; @@ -299,9 +315,11 @@ get_blend_value(const PartBundle *root) { float effect = (*cbi).second; nassertv(effect != 0.0f); + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel != (ChannelType *)NULL) { int frame = control->get_frame(); LVecBase3f iscale, ipos, ishear; @@ -345,7 +363,9 @@ get_blend_value(const PartBundle *root) { } if (net == 0.0f) { - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { scale /= net; diff --git a/panda/src/chan/movingPartScalar.cxx b/panda/src/chan/movingPartScalar.cxx index 002a3f661b..14d03e8b35 100644 --- a/panda/src/chan/movingPartScalar.cxx +++ b/panda/src/chan/movingPartScalar.cxx @@ -58,18 +58,24 @@ get_blend_value(const PartBundle *root) { if (cdata->_blend.empty()) { // No channel is bound; supply the default value. - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else if (cdata->_blend.size() == 1 && !cdata->_frame_blend_flag) { // A single value, the normal case. AnimControl *control = (*cdata->_blend.begin()).first; + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel == NULL) { // Nothing is actually bound here. - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { channel->get_value(control->get_frame(), _value); @@ -86,9 +92,11 @@ get_blend_value(const PartBundle *root) { float effect = (*cbi).second; nassertv(effect != 0.0f); + ChannelType *channel = NULL; int channel_index = control->get_channel_index(); - nassertv(channel_index >= 0 && channel_index < (int)_channels.size()); - ChannelType *channel = DCAST(ChannelType, _channels[channel_index]); + if (channel_index >= 0 && channel_index < (int)_channels.size()) { + channel = DCAST(ChannelType, _channels[channel_index]); + } if (channel != NULL) { ValueType v; channel->get_value(control->get_frame(), v); @@ -109,7 +117,9 @@ get_blend_value(const PartBundle *root) { } if (net == 0.0f) { - _value = _initial_value; + if (restore_initial_pose) { + _value = _initial_value; + } } else { _value /= net; diff --git a/panda/src/chan/partBundle.I b/panda/src/chan/partBundle.I index 6d863386be..57f5e9fe3e 100644 --- a/panda/src/chan/partBundle.I +++ b/panda/src/chan/partBundle.I @@ -13,6 +13,52 @@ //////////////////////////////////////////////////////////////////// +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::get_anim_preload +// Access: Published +// Description: Returns the AnimPreloadTable associated with +// the PartBundle. This table, if present, can be used +// for the benefit of load_bind_anim() to allow +// asynchronous binding. +//////////////////////////////////////////////////////////////////// +INLINE CPT(AnimPreloadTable) PartBundle:: +get_anim_preload() const { + return _anim_preload.get_read_pointer(); +} + +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::modify_anim_preload +// Access: Published +// Description: Returns a modifiable pointer to the AnimPreloadTable +// associated with the PartBundle, if any. +//////////////////////////////////////////////////////////////////// +INLINE PT(AnimPreloadTable) PartBundle:: +modify_anim_preload() { + return _anim_preload.get_write_pointer(); +} + +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::set_anim_preload +// Access: Published +// Description: Replaces the AnimPreloadTable associated with +// the PartBundle. +//////////////////////////////////////////////////////////////////// +INLINE void PartBundle:: +set_anim_preload(AnimPreloadTable *anim_preload) { + _anim_preload = anim_preload; +} + +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::clear_anim_preload +// Access: Published +// Description: Removes any AnimPreloadTable associated with +// the PartBundle. +//////////////////////////////////////////////////////////////////// +INLINE void PartBundle:: +clear_anim_preload() { + _anim_preload = NULL; +} + //////////////////////////////////////////////////////////////////// // Function: PartBundle::set_blend_type // Access: Published diff --git a/panda/src/chan/partBundle.cxx b/panda/src/chan/partBundle.cxx index 99802b9b8a..181e989ffa 100644 --- a/panda/src/chan/partBundle.cxx +++ b/panda/src/chan/partBundle.cxx @@ -15,7 +15,10 @@ #include "partBundle.h" #include "animBundle.h" +#include "animBundleNode.h" #include "animControl.h" +#include "loader.h" +#include "animPreloadTable.h" #include "config_chan.h" #include "bitArray.h" #include "string_utils.h" @@ -25,6 +28,7 @@ #include "bamReader.h" #include "bamWriter.h" #include "configVariableEnum.h" +#include "loaderOptions.h" #include @@ -49,6 +53,8 @@ PartBundle:: PartBundle(const PartBundle ©) : PartGroup(copy) { + _anim_preload = copy._anim_preload; + CDWriter cdata(_cycler, true); CDReader cdata_from(copy._cycler); cdata->_blend_type = cdata_from->_blend_type; @@ -81,6 +87,30 @@ make_copy() const { return new PartBundle(*this); } +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::merge_anim_preloads +// Access: Published +// Description: Copies the contents of the other PartBundle's preload +// table into this one. +//////////////////////////////////////////////////////////////////// +void PartBundle:: +merge_anim_preloads(const PartBundle *other) { + if (other->_anim_preload == (AnimPreloadTable *)NULL || + _anim_preload == other->_anim_preload) { + // No-op. + return; + } + + if (_anim_preload == (AnimPreloadTable *)NULL) { + // Trivial case. + _anim_preload = other->_anim_preload; + return; + } + + // Copy-on-write. + PT(AnimPreloadTable) anim_preload = _anim_preload.get_write_pointer(); + anim_preload->add_anims_from(other->_anim_preload.get_read_pointer()); +} //////////////////////////////////////////////////////////////////// // Function: PartBundle::set_anim_blend_flag @@ -239,45 +269,95 @@ write(ostream &out, int indent_level) const { PT(AnimControl) PartBundle:: bind_anim(AnimBundle *anim, int hierarchy_match_flags, const PartSubset &subset) { - nassertr(Thread::get_current_pipeline_stage() == 0, NULL); + PT(AnimControl) control = new AnimControl(anim->get_name(), this, 1.0f, 0); + if (do_bind_anim(control, anim, hierarchy_match_flags, subset)) { + return control; + } - // Make sure this pointer doesn't destruct during the lifetime of this - // method. - PT(AnimBundle) ptanim = anim; + return NULL; +} - if ((hierarchy_match_flags & HMF_ok_wrong_root_name) == 0) { - // Make sure the root names match. - if (get_name() != ptanim->get_name()) { - if (chan_cat.is_error()) { - chan_cat.error() - << "Root name of part (" << get_name() - << ") does not match that of anim (" << ptanim->get_name() - << ")\n"; - } +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::load_bind_anim +// Access: Published +// Description: Binds an animation to the bundle. The animation is +// loaded from the disk via the indicated Loader object. +// In other respects, this behaves similarly to +// bind_anim(), with the addition of asynchronous +// support. +// +// If allow_aysnc is true, the load will be asynchronous +// if possible. This requires that the animation +// basename can be found in the PartBundle's preload +// table (see get_anim_preload()). +// +// In an asynchronous load, the animation file will be +// loaded and bound in a sub-thread. This means that +// the animation will not necessarily be available at +// the time this method returns. You may still use the +// returned AnimControl immediately, though, but no +// visible effect will occur until the animation +// eventually becomes available. +// +// You can test AnimControl::is_pending() to see if the +// animation has been loaded yet. You can also set an +// event to be triggered when the animation finishes +// loading with AnimControl::set_pending_done_event(). +//////////////////////////////////////////////////////////////////// +PT(AnimControl) PartBundle:: +load_bind_anim(Loader *loader, const Filename &filename, + int hierarchy_match_flags, const PartSubset &subset, + bool allow_async) { + nassertr(loader != (Loader *)NULL, NULL); + + LoaderOptions anim_options(LoaderOptions::LF_search | + LoaderOptions::LF_report_errors | + LoaderOptions::LF_convert_anim); + string basename = filename.get_basename_wo_extension(); + + int anim_index = -1; + CPT(AnimPreloadTable) anim_preload = _anim_preload.get_read_pointer(); + if (anim_preload != (AnimPreloadTable *)NULL) { + anim_index = anim_preload->find_anim(basename); + } + + if (anim_index < 0 || !allow_async) { + // The animation is not present in the table, or allow_async is + // false. Therefore, perform an ordinary synchronous + // load-and-bind. + + PT(PandaNode) model = loader->load_sync(filename, anim_options); + if (model == (PandaNode *)NULL) { + // Couldn't load the file. return NULL; } + AnimBundle *anim = AnimBundleNode::find_anim_bundle(model); + if (anim == (AnimBundle *)NULL) { + // No anim bundle. + return NULL; + } + PT(AnimControl) control = bind_anim(anim, hierarchy_match_flags, subset); + if (control == (AnimControl *)NULL) { + // Couldn't bind. + return NULL; + } + control->set_anim_model(model); + return control; } - if (!check_hierarchy(anim, NULL, hierarchy_match_flags)) { - return NULL; - } + // The animation is present in the table, so we can perform an + // asynchronous load-and-bind. + float frame_rate = anim_preload->get_base_frame_rate(anim_index); + int num_frames = anim_preload->get_num_frames(anim_index); + PT(AnimControl) control = + new AnimControl(basename, this, frame_rate, num_frames); - plist holes; - int channel_index = 0; - pick_channel_index(holes, channel_index); + PT(BindAnimRequest) request = + new BindAnimRequest(filename, anim_options, control, + hierarchy_match_flags, subset); + loader->load_async(request); - if (!holes.empty()) { - channel_index = holes.front(); - } - - int joint_index = 0; - BitArray bound_joints; - if (subset.is_include_empty()) { - bound_joints = BitArray::all_on(); - } - bind_hierarchy(ptanim, channel_index, joint_index, - subset.is_include_empty(), bound_joints, subset); - return new AnimControl(this, anim, channel_index, bound_joints); + return control; } //////////////////////////////////////////////////////////////////// @@ -440,6 +520,59 @@ control_activated(AnimControl *control) { } } +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::do_bind_anim +// Access: Public +// Description: The internal implementation of bind_anim(), this +// receives a pointer to an uninitialized AnimControl +// and fills it in if the bind is successful. Returns +// true if successful, false otherwise. +//////////////////////////////////////////////////////////////////// +bool PartBundle:: +do_bind_anim(AnimControl *control, AnimBundle *anim, + int hierarchy_match_flags, const PartSubset &subset) { + nassertr(Thread::get_current_pipeline_stage() == 0, false); + + // Make sure this pointer doesn't destruct during the lifetime of this + // method. + PT(AnimBundle) ptanim = anim; + + if ((hierarchy_match_flags & HMF_ok_wrong_root_name) == 0) { + // Make sure the root names match. + if (get_name() != ptanim->get_name()) { + if (chan_cat.is_error()) { + chan_cat.error() + << "Root name of part (" << get_name() + << ") does not match that of anim (" << ptanim->get_name() + << ")\n"; + } + return false; + } + } + + if (!check_hierarchy(anim, NULL, hierarchy_match_flags)) { + return false; + } + + plist holes; + int channel_index = 0; + pick_channel_index(holes, channel_index); + + if (!holes.empty()) { + channel_index = holes.front(); + } + + int joint_index = 0; + BitArray bound_joints; + if (subset.is_include_empty()) { + bound_joints = BitArray::all_on(); + } + bind_hierarchy(ptanim, channel_index, joint_index, + subset.is_include_empty(), bound_joints, subset); + control->setup_anim(this, anim, channel_index, bound_joints); + return true; +} + //////////////////////////////////////////////////////////////////// // Function: PartBundle::add_node // Access: Protected, Virtual @@ -604,9 +737,26 @@ finalize(BamReader *) { void PartBundle:: write_datagram(BamWriter *manager, Datagram &dg) { PartGroup::write_datagram(manager, dg); + manager->write_pointer(dg, _anim_preload.get_read_pointer()); manager->write_cdata(dg, _cycler); } +//////////////////////////////////////////////////////////////////// +// Function: PartBundle::complete_pointers +// Access: Public +// Description: Takes in a vector of pointers to TypedWritable +// objects that correspond to all the requests for +// pointers that this object made to BamReader. +//////////////////////////////////////////////////////////////////// +int PartBundle:: +complete_pointers(TypedWritable **p_list, BamReader *manager) { + int pi = PartGroup::complete_pointers(p_list, manager); + + _anim_preload = DCAST(AnimPreloadTable, p_list[pi++]); + + return pi; +} + //////////////////////////////////////////////////////////////////// // Function: PartBundle::make_from_bam // Access: Protected @@ -634,7 +784,9 @@ make_from_bam(const FactoryParams ¶ms) { void PartBundle:: fillin(DatagramIterator &scan, BamReader *manager) { PartGroup::fillin(scan, manager); - + if (manager->get_file_minor_ver() >= 16) { + manager->read_pointer(scan); // _anim_preload + } if (manager->get_file_minor_ver() >= 10) { manager->read_cdata(scan, _cycler); } diff --git a/panda/src/chan/partBundle.h b/panda/src/chan/partBundle.h index 4abfa4e851..b94efc1830 100644 --- a/panda/src/chan/partBundle.h +++ b/panda/src/chan/partBundle.h @@ -20,6 +20,7 @@ #include "partGroup.h" #include "animControl.h" #include "partSubset.h" +#include "animPreloadTable.h" #include "pointerTo.h" #include "thread.h" #include "cycleData.h" @@ -30,11 +31,14 @@ #include "pvector.h" #include "transformState.h" #include "weakPointerTo.h" +#include "copyOnWritePointer.h" +class Loader; class AnimBundle; class PartBundleNode; class PartBundleNode; class TransformState; +class AnimPreloadTable; //////////////////////////////////////////////////////////////////// // Class : PartBundle @@ -58,6 +62,11 @@ public: virtual PartGroup *make_copy() const; PUBLISHED: + INLINE CPT(AnimPreloadTable) get_anim_preload() const; + INLINE PT(AnimPreloadTable) modify_anim_preload(); + INLINE void set_anim_preload(AnimPreloadTable *table); + INLINE void clear_anim_preload(); + void merge_anim_preloads(const PartBundle *other); // This is the parameter to set_blend_type() and specifies the kind // of blending operation to be performed when multiple controls are @@ -119,6 +128,11 @@ PUBLISHED: PT(AnimControl) bind_anim(AnimBundle *anim, int hierarchy_match_flags = 0, const PartSubset &subset = PartSubset()); + PT(AnimControl) load_bind_anim(Loader *loader, + const Filename &filename, + int hierarchy_match_flags, + const PartSubset &subset, + bool allow_async); bool freeze_joint(const string &joint_name, const TransformState *transform); bool control_joint(const string &joint_name, PandaNode *node); @@ -133,6 +147,9 @@ public: // bunch of friends. virtual void control_activated(AnimControl *control); + bool do_bind_anim(AnimControl *control, AnimBundle *anim, + int hierarchy_match_flags, const PartSubset &subset); + protected: virtual void add_node(PartBundleNode *node); virtual void remove_node(PartBundleNode *node); @@ -145,6 +162,8 @@ private: void recompute_net_blend(CData *cdata); void clear_and_stop_intersecting(AnimControl *control, CData *cdata); + COWPT(AnimPreloadTable) _anim_preload; + typedef pvector Nodes; Nodes _nodes; @@ -183,6 +202,8 @@ public: static void register_with_read_factory(); virtual void finalize(BamReader *manager); virtual void write_datagram(BamWriter *manager, Datagram &dg); + virtual int complete_pointers(TypedWritable **p_list, + BamReader *manager); protected: static TypedWritable *make_from_bam(const FactoryParams ¶ms); diff --git a/panda/src/chan/partGroup.cxx b/panda/src/chan/partGroup.cxx index 606edecd8b..08dc61d98b 100644 --- a/panda/src/chan/partGroup.cxx +++ b/panda/src/chan/partGroup.cxx @@ -253,6 +253,7 @@ sort_descendants() { bool PartGroup:: check_hierarchy(const AnimGroup *anim, const PartGroup *, int hierarchy_match_flags) const { + Thread::consider_yield(); if (anim->get_value_type() != get_value_type()) { if (chan_cat.is_error()) { chan_cat.error() @@ -507,6 +508,7 @@ void PartGroup:: bind_hierarchy(AnimGroup *anim, int channel_index, int &joint_index, bool is_included, BitArray &bound_joints, const PartSubset &subset) { + Thread::consider_yield(); if (subset.matches_include(get_name())) { is_included = true; } else if (subset.matches_exclude(get_name())) { diff --git a/panda/src/char/character.cxx b/panda/src/char/character.cxx index 5f3de899ef..9a36c70770 100644 --- a/panda/src/char/character.cxx +++ b/panda/src/char/character.cxx @@ -281,7 +281,11 @@ merge_bundles(PartBundle *old_bundle, PartBundle *new_bundle) { void Character:: merge_bundles(PartBundleHandle *old_bundle_handle, PartBundleHandle *new_bundle_handle) { - update_bundle(old_bundle_handle, new_bundle_handle->get_bundle()); + PartBundle *old_bundle = old_bundle_handle->get_bundle(); + PartBundle *new_bundle = new_bundle_handle->get_bundle(); + new_bundle->merge_anim_preloads(old_bundle); + + update_bundle(old_bundle_handle, new_bundle); } //////////////////////////////////////////////////////////////////// diff --git a/panda/src/egg/Sources.pp b/panda/src/egg/Sources.pp index 50d4e7f78b..82f3f0a11c 100644 --- a/panda/src/egg/Sources.pp +++ b/panda/src/egg/Sources.pp @@ -12,7 +12,9 @@ #define COMBINED_SOURCES $[TARGET]_composite1.cxx $[TARGET]_composite2.cxx #define SOURCES \ - config_egg.h eggAnimData.I eggAnimData.h eggAttributes.I \ + config_egg.h eggAnimData.I eggAnimData.h \ + eggAnimPreload.I eggAnimPreload.h \ + eggAttributes.I \ eggAttributes.h eggBin.h eggBinMaker.h eggComment.I \ eggComment.h \ eggCompositePrimitive.I eggCompositePrimitive.h \ @@ -54,7 +56,9 @@ vector_PT_EggTexture.h pt_EggVertex.h vector_PT_EggVertex.h #define INCLUDED_SOURCES \ - config_egg.cxx eggAnimData.cxx eggAttributes.cxx eggBin.cxx \ + config_egg.cxx eggAnimData.cxx \ + eggAnimPreload.cxx \ + eggAttributes.cxx eggBin.cxx \ eggBinMaker.cxx eggComment.cxx \ eggCompositePrimitive.cxx \ eggCoordinateSystem.cxx \ @@ -85,6 +89,7 @@ #define INSTALL_HEADERS \ eggAnimData.I eggAnimData.h \ + eggAnimPreload.I eggAnimPreload.h \ eggAttributes.I eggAttributes.h eggBin.h eggBinMaker.h eggComment.I \ eggComment.h \ eggCompositePrimitive.I eggCompositePrimitive.h \ diff --git a/panda/src/egg/config_egg.cxx b/panda/src/egg/config_egg.cxx index d8dab44900..5fd2efa695 100644 --- a/panda/src/egg/config_egg.cxx +++ b/panda/src/egg/config_egg.cxx @@ -15,6 +15,7 @@ #include "config_egg.h" #include "eggRenderMode.h" #include "eggAnimData.h" +#include "eggAnimPreload.h" #include "eggAttributes.h" #include "eggBin.h" #include "eggBinMaker.h" @@ -166,6 +167,7 @@ init_libegg() { EggRenderMode::init_type(); EggAnimData::init_type(); + EggAnimPreload::init_type(); EggAttributes::init_type(); EggBin::init_type(); EggBinMaker::init_type(); diff --git a/panda/src/egg/eggAnimPreload.I b/panda/src/egg/eggAnimPreload.I new file mode 100644 index 0000000000..310890dc95 --- /dev/null +++ b/panda/src/egg/eggAnimPreload.I @@ -0,0 +1,145 @@ +// Filename: eggAnimPreload.I +// Created by: drose (06Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::Constructor +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE EggAnimPreload:: +EggAnimPreload(const string &name) : EggNode(name) { + _has_fps = false; + _has_num_frames = false; +} + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::Copy constructor +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE EggAnimPreload:: +EggAnimPreload(const EggAnimPreload ©) : + EggNode(copy), + _fps(copy._fps), + _has_fps(copy._has_fps), + _num_frames(copy._num_frames), + _has_num_frames(copy._has_num_frames) +{ +} + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::Copy assignment operator +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE EggAnimPreload &EggAnimPreload:: +operator = (const EggAnimPreload ©) { + EggNode::operator = (copy); + _fps = copy._fps; + _has_fps = copy._has_fps; + _num_frames = copy._num_frames; + _has_num_frames = copy._has_num_frames; + + return *this; +} + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::set_fps +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE void EggAnimPreload:: +set_fps(double fps) { + _fps = fps; + _has_fps = true; +} + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::clear_fps +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE void EggAnimPreload:: +clear_fps() { + _has_fps = false; +} + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::has_fps +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE bool EggAnimPreload:: +has_fps() const { + return _has_fps; +} + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::get_fps +// Access: Public +// Description: This is only valid if has_fps() returns true. +//////////////////////////////////////////////////////////////////// +INLINE double EggAnimPreload:: +get_fps() const { + nassertr(has_fps(), 0.0); + return _fps; +} + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::set_num_frames +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE void EggAnimPreload:: +set_num_frames(int num_frames) { + _num_frames = num_frames; + _has_num_frames = true; +} + + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::clear_num_frames +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE void EggAnimPreload:: +clear_num_frames() { + _has_num_frames = false; +} + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::has_num_frames +// Access: Public +// Description: +//////////////////////////////////////////////////////////////////// +INLINE bool EggAnimPreload:: +has_num_frames() const { + return _has_num_frames; +} + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::get_num_frames +// Access: Public +// Description: This is only valid if has_num_frames() returns true. +//////////////////////////////////////////////////////////////////// +INLINE int EggAnimPreload:: +get_num_frames() const { + nassertr(has_num_frames(), 0); + return _num_frames; +} diff --git a/panda/src/egg/eggAnimPreload.cxx b/panda/src/egg/eggAnimPreload.cxx new file mode 100644 index 0000000000..56cab9a683 --- /dev/null +++ b/panda/src/egg/eggAnimPreload.cxx @@ -0,0 +1,45 @@ +// Filename: eggAnimPreload.cxx +// Created by: drose (06Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#include "eggAnimPreload.h" + +#include "string_utils.h" +#include "indent.h" + +TypeHandle EggAnimPreload::_type_handle; + +//////////////////////////////////////////////////////////////////// +// Function: EggAnimPreload::write +// Access: Public, Virtual +// Description: Writes the table and all of its children to the +// indicated output stream in Egg format. +//////////////////////////////////////////////////////////////////// +void EggAnimPreload:: +write(ostream &out, int indent_level) const { + test_under_integrity(); + + write_header(out, indent_level, ""); + + if (has_fps()) { + indent(out, indent_level + 2) + << " fps { " << get_fps() << " }\n"; + } + + if (has_num_frames()) { + indent(out, indent_level + 2) + << " frames { " << get_num_frames() << " }\n"; + } + + indent(out, indent_level) << "}\n"; +} diff --git a/panda/src/egg/eggAnimPreload.h b/panda/src/egg/eggAnimPreload.h new file mode 100644 index 0000000000..1bf7fe0914 --- /dev/null +++ b/panda/src/egg/eggAnimPreload.h @@ -0,0 +1,71 @@ +// Filename: eggAnimPreload.h +// Created by: drose (06Aug08) +// +//////////////////////////////////////////////////////////////////// +// +// PANDA 3D SOFTWARE +// Copyright (c) Carnegie Mellon University. All rights reserved. +// +// All use of this software is subject to the terms of the revised BSD +// license. You should have received a copy of this license along +// with this source code in a file named "LICENSE." +// +//////////////////////////////////////////////////////////////////// + +#ifndef EGGANIMPRELOAD_H +#define EGGANIMPRELOAD_H + +#include "pandabase.h" + +#include "eggNode.h" + +//////////////////////////////////////////////////////////////////// +// Class : EggAnimPreload +// Description : This corresponds to an entry. +//////////////////////////////////////////////////////////////////// +class EXPCL_PANDAEGG EggAnimPreload : public EggNode { +PUBLISHED: + INLINE EggAnimPreload(const string &name = ""); + INLINE EggAnimPreload(const EggAnimPreload ©); + INLINE EggAnimPreload &operator = (const EggAnimPreload ©); + + INLINE void set_fps(double fps); + INLINE void clear_fps(); + INLINE bool has_fps() const; + INLINE double get_fps() const; + + INLINE void set_num_frames(int num_frames); + INLINE void clear_num_frames(); + INLINE bool has_num_frames() const; + INLINE int get_num_frames() const; + + virtual void write(ostream &out, int indent_level) const; + +private: + double _fps; + bool _has_fps; + int _num_frames; + bool _has_num_frames; + +public: + static TypeHandle get_class_type() { + return _type_handle; + } + static void init_type() { + EggNode::init_type(); + register_type(_type_handle, "EggAnimPreload", + EggNode::get_class_type()); + } + virtual TypeHandle get_type() const { + return get_class_type(); + } + virtual TypeHandle force_init_type() {init_type(); return get_class_type();} + +private: + static TypeHandle _type_handle; +}; + +#include "eggAnimPreload.I" + +#endif + diff --git a/panda/src/egg/egg_composite1.cxx b/panda/src/egg/egg_composite1.cxx index 84415611b5..961b702a28 100644 --- a/panda/src/egg/egg_composite1.cxx +++ b/panda/src/egg/egg_composite1.cxx @@ -1,5 +1,6 @@ #include "config_egg.cxx" #include "eggAnimData.cxx" +#include "eggAnimPreload.cxx" #include "eggAttributes.cxx" #include "eggBin.cxx" #include "eggBinMaker.cxx" diff --git a/panda/src/egg/lexer.cxx.prebuilt b/panda/src/egg/lexer.cxx.prebuilt index 902235dc10..7154a3c10b 100644 --- a/panda/src/egg/lexer.cxx.prebuilt +++ b/panda/src/egg/lexer.cxx.prebuilt @@ -1,3000 +1,2996 @@ -#define yy_create_buffer eggyy_create_buffer -#define yy_delete_buffer eggyy_delete_buffer -#define yy_scan_buffer eggyy_scan_buffer -#define yy_scan_string eggyy_scan_string -#define yy_scan_bytes eggyy_scan_bytes -#define yy_flex_debug eggyy_flex_debug -#define yy_init_buffer eggyy_init_buffer -#define yy_flush_buffer eggyy_flush_buffer -#define yy_load_buffer_state eggyy_load_buffer_state -#define yy_switch_to_buffer eggyy_switch_to_buffer -#define yyin eggyyin -#define yyleng eggyyleng -#define yylex eggyylex -#define yyout eggyyout -#define yyrestart eggyyrestart -#define yytext eggyytext -#define yywrap eggyywrap - -#line 20 "lex.yy.c" -/* A lexical scanner generated by flex */ - -/* Scanner skeleton version: - * $Header$ - */ - -#define FLEX_SCANNER -#define YY_FLEX_MAJOR_VERSION 2 -#define YY_FLEX_MINOR_VERSION 5 - -#include -#include - -/* cfront 1.2 defines "c_plusplus" instead of "__cplusplus" */ -#ifdef c_plusplus -#ifndef __cplusplus -#define __cplusplus -#endif -#endif - - -#ifdef __cplusplus - -#include -#ifndef _WIN32 -#endif - -/* Use prototypes in function declarations. */ -#define YY_USE_PROTOS - -/* The "const" storage-class-modifier is valid. */ -#define YY_USE_CONST - -#else /* ! __cplusplus */ - -#if __STDC__ - -#define YY_USE_PROTOS -#define YY_USE_CONST - -#endif /* __STDC__ */ -#endif /* ! __cplusplus */ - -#ifdef __TURBOC__ - #pragma warn -rch - #pragma warn -use -#include -#include -#define YY_USE_CONST -#define YY_USE_PROTOS -#endif - -#ifdef YY_USE_CONST -#define yyconst const -#else -#define yyconst -#endif - - -#ifdef YY_USE_PROTOS -#define YY_PROTO(proto) proto -#else -#define YY_PROTO(proto) () -#endif - - -/* Returned upon end-of-file. */ -#define YY_NULL 0 - -/* Promotes a possibly negative, possibly signed char to an unsigned - * integer for use as an array index. If the signed char is negative, - * we want to instead treat it as an 8-bit unsigned char, hence the - * double cast. - */ -#define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c) - -/* Enter a start condition. This macro really ought to take a parameter, - * but we do it the disgusting crufty way forced on us by the ()-less - * definition of BEGIN. - */ -#define BEGIN yy_start = 1 + 2 * - -/* Translate the current start state into a value that can be later handed - * to BEGIN to return to the state. The YYSTATE alias is for lex - * compatibility. - */ -#define YY_START ((yy_start - 1) / 2) -#define YYSTATE YY_START - -/* Action number for EOF rule of a given start state. */ -#define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1) - -/* Special action meaning "start processing a new file". */ -#define YY_NEW_FILE yyrestart( yyin ) - -#define YY_END_OF_BUFFER_CHAR 0 - -/* Size of default input buffer. */ -#define YY_BUF_SIZE 16384 - -typedef struct yy_buffer_state *YY_BUFFER_STATE; - -extern int yyleng; -extern FILE *yyin, *yyout; - -#define EOB_ACT_CONTINUE_SCAN 0 -#define EOB_ACT_END_OF_FILE 1 -#define EOB_ACT_LAST_MATCH 2 - -/* The funky do-while in the following #define is used to turn the definition - * int a single C statement (which needs a semi-colon terminator). This - * avoids problems with code like: - * - * if ( condition_holds ) - * yyless( 5 ); - * else - * do_something_else(); - * - * Prior to using the do-while the compiler would get upset at the - * "else" because it interpreted the "if" statement as being all - * done when it reached the ';' after the yyless() call. - */ - -/* Return all but the first 'n' matched characters back to the input stream. */ - -#define yyless(n) \ - do \ - { \ - /* Undo effects of setting up yytext. */ \ - *yy_cp = yy_hold_char; \ - YY_RESTORE_YY_MORE_OFFSET \ - yy_c_buf_p = yy_cp = yy_bp + n - YY_MORE_ADJ; \ - YY_DO_BEFORE_ACTION; /* set up yytext again */ \ - } \ - while ( 0 ) - -#define unput(c) yyunput( c, yytext_ptr ) - -/* The following is because we cannot portably get our hands on size_t - * (without autoconf's help, which isn't available because we want - * flex-generated scanners to compile on their own). - */ -typedef unsigned int yy_size_t; - - -struct yy_buffer_state - { - FILE *yy_input_file; - - char *yy_ch_buf; /* input buffer */ - char *yy_buf_pos; /* current position in input buffer */ - - /* Size of input buffer in bytes, not including room for EOB - * characters. - */ - yy_size_t yy_buf_size; - - /* Number of characters read into yy_ch_buf, not including EOB - * characters. - */ - int yy_n_chars; - - /* Whether we "own" the buffer - i.e., we know we created it, - * and can realloc() it to grow it, and should free() it to - * delete it. - */ - int yy_is_our_buffer; - - /* Whether this is an "interactive" input source; if so, and - * if we're using stdio for input, then we want to use getc() - * instead of fread(), to make sure we stop fetching input after - * each newline. - */ - int yy_is_interactive; - - /* Whether we're considered to be at the beginning of a line. - * If so, '^' rules will be active on the next match, otherwise - * not. - */ - int yy_at_bol; - - /* Whether to try to fill the input buffer when we reach the - * end of it. - */ - int yy_fill_buffer; - - int yy_buffer_status; -#define YY_BUFFER_NEW 0 -#define YY_BUFFER_NORMAL 1 - /* When an EOF's been seen but there's still some text to process - * then we mark the buffer as YY_EOF_PENDING, to indicate that we - * shouldn't try reading from the input source any more. We might - * still have a bunch of tokens to match, though, because of - * possible backing-up. - * - * When we actually see the EOF, we change the status to "new" - * (via yyrestart()), so that the user can continue scanning by - * just pointing yyin at a new input file. - */ -#define YY_BUFFER_EOF_PENDING 2 - }; - -static YY_BUFFER_STATE yy_current_buffer = 0; - -/* We provide macros for accessing buffer states in case in the - * future we want to put the buffer states in a more general - * "scanner state". - */ -#define YY_CURRENT_BUFFER yy_current_buffer - - -/* yy_hold_char holds the character lost when yytext is formed. */ -static char yy_hold_char; - -static int yy_n_chars; /* number of characters read into yy_ch_buf */ - - -int yyleng; - -/* Points to current character in buffer. */ -static char *yy_c_buf_p = (char *) 0; -static int yy_init = 1; /* whether we need to initialize */ -static int yy_start = 0; /* start state number */ - -/* Flag which is used to allow yywrap()'s to do buffer switches - * instead of setting up a fresh yyin. A bit of a hack ... - */ -static int yy_did_buffer_switch_on_eof; - -void yyrestart YY_PROTO(( FILE *input_file )); - -void yy_switch_to_buffer YY_PROTO(( YY_BUFFER_STATE new_buffer )); -void yy_load_buffer_state YY_PROTO(( void )); -YY_BUFFER_STATE yy_create_buffer YY_PROTO(( FILE *file, int size )); -void yy_delete_buffer YY_PROTO(( YY_BUFFER_STATE b )); -void yy_init_buffer YY_PROTO(( YY_BUFFER_STATE b, FILE *file )); -void yy_flush_buffer YY_PROTO(( YY_BUFFER_STATE b )); -#define YY_FLUSH_BUFFER yy_flush_buffer( yy_current_buffer ) - -YY_BUFFER_STATE yy_scan_buffer YY_PROTO(( char *base, yy_size_t size )); -YY_BUFFER_STATE yy_scan_string YY_PROTO(( yyconst char *yy_str )); -YY_BUFFER_STATE yy_scan_bytes YY_PROTO(( yyconst char *bytes, int len )); - -static void *yy_flex_alloc YY_PROTO(( yy_size_t )); -static void *yy_flex_realloc YY_PROTO(( void *, yy_size_t )); -static void yy_flex_free YY_PROTO(( void * )); - -#define yy_new_buffer yy_create_buffer - -#define yy_set_interactive(is_interactive) \ - { \ - if ( ! yy_current_buffer ) \ - yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \ - yy_current_buffer->yy_is_interactive = is_interactive; \ - } - -#define yy_set_bol(at_bol) \ - { \ - if ( ! yy_current_buffer ) \ - yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \ - yy_current_buffer->yy_at_bol = at_bol; \ - } - -#define YY_AT_BOL() (yy_current_buffer->yy_at_bol) - -typedef unsigned char YY_CHAR; -FILE *yyin = (FILE *) 0, *yyout = (FILE *) 0; -typedef int yy_state_type; -extern char *yytext; -#define yytext_ptr yytext - -static yy_state_type yy_get_previous_state YY_PROTO(( void )); -static yy_state_type yy_try_NUL_trans YY_PROTO(( yy_state_type current_state )); -static int yy_get_next_buffer YY_PROTO(( void )); -static void yy_fatal_error YY_PROTO(( yyconst char msg[] )); - -/* Done after the current pattern has been matched and before the - * corresponding action - sets up yytext. - */ -#define YY_DO_BEFORE_ACTION \ - yytext_ptr = yy_bp; \ - yyleng = (int) (yy_cp - yy_bp); \ - yy_hold_char = *yy_cp; \ - *yy_cp = '\0'; \ - yy_c_buf_p = yy_cp; - -#define YY_NUM_RULES 100 -#define YY_END_OF_BUFFER 101 -static yyconst short int yy_accept[569] = - { 0, - 0, 0, 101, 99, 2, 1, 98, 99, 99, 99, - 99, 90, 90, 90, 99, 99, 99, 5, 99, 1, - 99, 90, 90, 99, 90, 4, 3, 90, 92, 99, - 91, 90, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 90, 99, 3, 3, 92, 99, - 90, 91, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 66, 99, 99, 99, 94, - 99, 99, 95, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 18, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 32, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 81, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - - 99, 99, 99, 99, 24, 99, 99, 99, 99, 22, - 99, 99, 99, 99, 99, 31, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 52, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 67, 99, 99, 99, 99, - 99, 99, 99, 99, 78, 99, 99, 99, 99, 99, - 99, 93, 99, 96, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 19, 99, 99, 99, 99, - 23, 99, 28, 99, 99, 99, 99, 99, 99, 37, - 38, 99, 99, 99, 43, 99, 99, 99, 99, 99, - - 99, 99, 53, 99, 55, 56, 57, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 74, - 99, 77, 99, 99, 99, 99, 99, 99, 93, 97, - 99, 7, 99, 99, 99, 12, 99, 99, 99, 99, - 99, 99, 99, 21, 26, 99, 99, 30, 99, 99, - 33, 34, 99, 99, 42, 99, 99, 99, 99, 48, - 99, 99, 99, 99, 99, 99, 60, 99, 99, 99, - 65, 99, 99, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 11, 13, 99, - 99, 99, 99, 99, 99, 99, 99, 99, 99, 99, - - 99, 99, 44, 99, 99, 99, 99, 99, 99, 54, - 58, 59, 99, 99, 63, 99, 99, 99, 99, 99, - 99, 99, 99, 99, 99, 99, 99, 84, 99, 99, - 99, 99, 99, 99, 99, 14, 15, 99, 99, 99, - 20, 99, 99, 35, 99, 99, 40, 41, 99, 99, - 99, 99, 99, 51, 99, 62, 99, 68, 69, 70, - 99, 99, 99, 99, 79, 80, 82, 83, 99, 99, - 99, 99, 99, 99, 10, 99, 99, 25, 99, 99, - 36, 39, 99, 99, 99, 99, 99, 61, 99, 71, - 99, 99, 99, 99, 99, 99, 99, 88, 99, 99, - - 8, 99, 16, 99, 99, 99, 99, 99, 99, 99, - 99, 99, 72, 73, 99, 99, 99, 99, 87, 99, - 99, 99, 99, 99, 29, 45, 99, 47, 49, 50, - 99, 99, 99, 85, 86, 99, 6, 99, 99, 99, - 99, 99, 75, 99, 89, 99, 99, 99, 46, 99, - 99, 99, 99, 99, 99, 76, 99, 99, 99, 99, - 9, 99, 99, 64, 17, 99, 27, 0 - } ; - -static yyconst int yy_ec[256] = - { 0, - 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, - 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 2, 1, 4, 5, 6, 1, 1, 1, 1, - 1, 7, 8, 1, 9, 10, 11, 12, 13, 14, - 15, 16, 14, 14, 14, 14, 14, 1, 1, 17, - 1, 18, 1, 1, 20, 21, 22, 23, 24, 25, - 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, - 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, - 1, 1, 1, 1, 19, 1, 20, 21, 22, 23, - - 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, - 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, - 44, 45, 46, 1, 46, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1 - } ; - -static yyconst int yy_meta[47] = - { 0, - 1, 2, 3, 2, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 2 - } ; - -static yyconst short int yy_base[574] = - { 0, - 0, 45, 690, 0, 691, 0, 691, 8, 82, 22, - 18, 101, 9, 20, 124, 656, 668, 691, 0, 0, - 52, 29, 59, 654, 69, 0, 40, 114, 14, 160, - 165, 186, 79, 177, 199, 12, 649, 657, 651, 649, - 649, 11, 86, 36, 50, 647, 75, 206, 172, 99, - 115, 655, 654, 645, 244, 652, 75, 0, 19, 210, - 238, 0, 648, 630, 654, 104, 640, 652, 637, 163, - 652, 632, 630, 629, 632, 639, 627, 622, 618, 628, - 629, 620, 624, 622, 223, 628, 621, 621, 619, 613, - 628, 626, 612, 611, 618, 623, 606, 185, 619, 622, - - 603, 621, 620, 603, 618, 609, 79, 593, 611, 242, - 595, 603, 602, 613, 600, 0, 599, 591, 595, 0, - 614, 597, 0, 591, 595, 600, 590, 586, 596, 581, - 579, 585, 182, 578, 0, 575, 595, 573, 574, 589, - 585, 590, 562, 586, 581, 585, 563, 584, 0, 570, - 561, 566, 559, 573, 561, 51, 571, 569, 561, 571, - 567, 566, 550, 555, 543, 568, 565, 162, 551, 552, - 542, 558, 541, 548, 560, 551, 198, 543, 542, 549, - 111, 555, 539, 538, 0, 537, 536, 529, 561, 523, - 532, 539, 539, 538, 540, 523, 528, 551, 533, 528, - - 531, 520, 530, 534, 0, 531, 518, 529, 523, 0, - 529, 514, 527, 517, 508, 0, 502, 521, 501, 501, - 520, 519, 499, 507, 503, 515, 512, 493, 508, 492, - 508, 488, 500, 0, 507, 485, 505, 504, 503, 492, - 112, 495, 490, 495, 492, 0, 491, 486, 473, 486, - 473, 492, 476, 490, 0, 473, 472, 471, 470, 479, - 482, 259, 476, 0, 463, 481, 464, 465, 472, 477, - 471, 470, 459, 458, 462, 0, 456, 468, 469, 468, - 0, 457, 0, 460, 465, 459, 448, 462, 461, 0, - 0, 450, 434, 458, 0, 444, 209, 435, 455, 439, - - 440, 436, 0, 445, 0, 0, 0, 436, 430, 448, - 432, 431, 436, 444, 428, 422, 422, 419, 117, 0, - 431, 0, 417, 416, 415, 414, 409, 418, 0, 0, - 428, 0, 429, 428, 429, 0, 428, 421, 405, 419, - 409, 419, 409, 0, 0, 417, 418, 0, 413, 414, - 0, 0, 415, 155, 0, 416, 393, 392, 392, 0, - 404, 401, 395, 409, 408, 407, 0, 402, 397, 222, - 0, 383, 382, 396, 392, 384, 397, 385, 377, 376, - 375, 374, 258, 383, 370, 372, 377, 0, 0, 389, - 388, 372, 384, 379, 384, 360, 377, 381, 374, 366, - - 378, 377, 0, 357, 356, 348, 367, 364, 371, 0, - 0, 0, 364, 369, 0, 352, 367, 366, 365, 344, - 344, 341, 355, 360, 359, 358, 357, 0, 341, 339, - 348, 339, 333, 346, 350, 0, 0, 328, 327, 347, - 0, 340, 339, 0, 344, 343, 0, 0, 319, 334, - 323, 324, 329, 0, 337, 0, 321, 0, 0, 0, - 335, 320, 327, 239, 0, 0, 0, 0, 322, 315, - 323, 165, 306, 245, 0, 328, 321, 0, 307, 306, - 0, 0, 318, 321, 316, 300, 299, 0, 314, 0, - 318, 317, 314, 294, 300, 300, 312, 0, 291, 304, - - 0, 303, 0, 288, 286, 306, 305, 300, 303, 302, - 301, 290, 0, 0, 284, 279, 297, 296, 0, 307, - 294, 278, 266, 285, 0, 0, 284, 0, 0, 0, - 268, 288, 277, 0, 0, 276, 0, 253, 253, 247, - 271, 260, 0, 252, 0, 262, 246, 234, 0, 231, - 237, 209, 211, 200, 187, 0, 175, 134, 126, 123, - 0, 71, 43, 0, 0, 33, 0, 691, 295, 0, - 298, 300, 302 - } ; - -static yyconst short int yy_def[574] = - { 0, - 569, 569, 568, 570, 568, 571, 568, 570, 570, 570, - 570, 570, 12, 12, 570, 570, 570, 568, 570, 571, - 570, 12, 12, 570, 570, 570, 572, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 572, 573, 570, 570, - 570, 31, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 262, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - 570, 570, 570, 570, 570, 570, 570, 0, 568, 568, - 568, 568, 568 - } ; - -static yyconst short int yy_nxt[738] = - { 0, - 19, 5, 6, 7, 568, 568, 568, 8, 9, 10, - 11, 12, 13, 14, 14, 14, 15, 21, 32, 22, - 22, 22, 22, 22, 26, 59, 59, 16, 27, 19, - 59, 59, 17, 25, 25, 25, 25, 25, 88, 81, - 19, 58, 82, 58, 89, 18, 5, 6, 7, 19, - 567, 19, 8, 9, 10, 11, 12, 13, 14, 14, - 14, 15, 19, 25, 25, 25, 25, 25, 55, 93, - 95, 19, 16, 566, 223, 94, 58, 17, 58, 19, - 25, 25, 25, 25, 25, 58, 96, 224, 565, 97, - 18, 21, 30, 22, 23, 22, 22, 22, 99, 174, - - 100, 19, 64, 65, 175, 90, 66, 112, 101, 24, - 28, 176, 22, 22, 22, 22, 22, 113, 67, 91, - 58, 29, 92, 115, 30, 25, 25, 25, 25, 25, - 253, 309, 116, 117, 127, 310, 128, 30, 118, 114, - 564, 376, 254, 31, 33, 34, 35, 377, 36, 37, - 38, 39, 40, 41, 42, 43, 44, 45, 46, 563, - 47, 48, 49, 50, 51, 562, 52, 60, 60, 401, - 402, 61, 61, 61, 61, 61, 62, 62, 62, 62, - 62, 236, 498, 499, 62, 62, 62, 62, 62, 62, - 63, 107, 561, 132, 133, 108, 134, 25, 25, 25, - - 25, 25, 109, 68, 237, 238, 239, 69, 110, 30, - 70, 102, 164, 201, 111, 165, 202, 71, 72, 560, - 73, 61, 61, 61, 61, 61, 74, 103, 248, 104, - 357, 75, 105, 559, 558, 76, 249, 77, 78, 415, - 149, 79, 80, 416, 150, 557, 358, 106, 122, 61, - 61, 61, 61, 61, 556, 25, 25, 25, 25, 25, - 151, 179, 501, 493, 555, 180, 502, 30, 554, 181, - 329, 329, 329, 329, 329, 428, 494, 429, 329, 329, - 329, 329, 329, 329, 553, 552, 551, 550, 549, 548, - 547, 546, 430, 545, 431, 4, 4, 4, 20, 20, - - 57, 57, 58, 58, 544, 543, 542, 541, 540, 539, - 538, 537, 536, 535, 534, 533, 532, 531, 530, 529, - 528, 527, 526, 525, 524, 523, 522, 521, 520, 519, - 518, 517, 516, 515, 514, 513, 512, 511, 510, 509, - 508, 507, 506, 505, 504, 503, 500, 497, 496, 495, - 492, 491, 490, 489, 488, 487, 486, 485, 484, 483, - 482, 481, 480, 479, 478, 477, 476, 475, 474, 473, - 472, 471, 470, 469, 468, 467, 466, 465, 464, 463, - 462, 461, 460, 459, 458, 457, 456, 455, 454, 453, - 452, 451, 450, 449, 448, 447, 446, 445, 444, 443, - - 442, 441, 440, 439, 438, 437, 436, 435, 434, 433, - 432, 427, 426, 425, 424, 423, 422, 421, 420, 419, - 418, 417, 414, 413, 412, 411, 410, 409, 408, 407, - 406, 405, 404, 403, 400, 399, 398, 397, 396, 395, - 394, 393, 392, 391, 390, 389, 388, 387, 386, 385, - 384, 383, 382, 381, 380, 379, 378, 375, 374, 373, - 372, 371, 370, 369, 368, 367, 366, 365, 364, 363, - 362, 361, 360, 359, 356, 355, 354, 353, 352, 351, - 350, 349, 348, 347, 346, 345, 344, 343, 342, 341, - 340, 339, 338, 337, 336, 335, 334, 333, 332, 331, - - 330, 328, 327, 326, 325, 324, 323, 322, 321, 320, - 319, 318, 317, 316, 315, 314, 313, 312, 311, 308, - 307, 306, 305, 304, 303, 302, 301, 300, 299, 298, - 297, 296, 295, 294, 293, 292, 291, 290, 289, 288, - 287, 286, 285, 284, 283, 282, 281, 280, 279, 278, - 277, 276, 275, 274, 273, 272, 271, 270, 269, 268, - 267, 266, 265, 264, 263, 262, 261, 260, 259, 258, - 257, 256, 255, 252, 251, 250, 247, 246, 245, 244, - 243, 242, 241, 240, 235, 234, 233, 232, 231, 230, - 229, 228, 227, 226, 225, 222, 221, 220, 219, 218, - - 217, 216, 215, 214, 213, 212, 211, 210, 209, 208, - 207, 206, 205, 204, 203, 200, 199, 198, 197, 196, - 195, 194, 193, 192, 191, 190, 189, 188, 187, 186, - 185, 184, 183, 182, 178, 177, 173, 172, 171, 170, - 169, 168, 167, 166, 163, 162, 161, 160, 159, 158, - 157, 156, 155, 154, 153, 152, 148, 147, 146, 145, - 144, 143, 142, 141, 140, 139, 138, 137, 136, 135, - 131, 130, 129, 126, 125, 124, 123, 121, 120, 119, - 98, 87, 86, 85, 84, 83, 56, 54, 53, 568, - 3, 568, 568, 568, 568, 568, 568, 568, 568, 568, - - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568 - } ; - -static yyconst short int yy_chk[738] = - { 0, - 570, 1, 1, 1, 0, 0, 0, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 8, 13, 8, - 8, 8, 8, 8, 11, 29, 29, 1, 11, 13, - 59, 59, 1, 10, 10, 10, 10, 10, 42, 36, - 14, 27, 36, 27, 42, 1, 2, 2, 2, 22, - 566, 13, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 14, 21, 21, 21, 21, 21, 23, 44, - 45, 22, 2, 563, 156, 44, 57, 2, 57, 23, - 25, 25, 25, 25, 25, 27, 45, 156, 562, 45, - 2, 9, 25, 9, 9, 9, 9, 9, 47, 107, - - 47, 23, 33, 33, 107, 43, 33, 50, 47, 9, - 12, 107, 12, 12, 12, 12, 12, 50, 33, 43, - 57, 12, 43, 51, 12, 28, 28, 28, 28, 28, - 181, 241, 51, 51, 66, 241, 66, 28, 51, 50, - 560, 319, 181, 12, 15, 15, 15, 319, 15, 15, - 15, 15, 15, 15, 15, 15, 15, 15, 15, 559, - 15, 15, 15, 15, 15, 558, 15, 30, 30, 354, - 354, 30, 30, 30, 30, 30, 31, 31, 31, 31, - 31, 168, 472, 472, 31, 31, 31, 31, 31, 31, - 32, 49, 557, 70, 70, 49, 70, 32, 32, 32, - - 32, 32, 49, 34, 168, 168, 168, 34, 49, 32, - 34, 48, 98, 133, 49, 98, 133, 34, 35, 555, - 35, 60, 60, 60, 60, 60, 35, 48, 177, 48, - 297, 35, 48, 554, 553, 35, 177, 35, 35, 370, - 85, 35, 35, 370, 85, 552, 297, 48, 55, 61, - 61, 61, 61, 61, 551, 55, 55, 55, 55, 55, - 85, 110, 474, 464, 550, 110, 474, 55, 548, 110, - 262, 262, 262, 262, 262, 383, 464, 383, 262, 262, - 262, 262, 262, 262, 547, 546, 544, 542, 541, 540, - 539, 538, 383, 536, 383, 569, 569, 569, 571, 571, - - 572, 572, 573, 573, 533, 532, 531, 527, 524, 523, - 522, 521, 520, 518, 517, 516, 515, 512, 511, 510, - 509, 508, 507, 506, 505, 504, 502, 500, 499, 497, - 496, 495, 494, 493, 492, 491, 489, 487, 486, 485, - 484, 483, 480, 479, 477, 476, 473, 471, 470, 469, - 463, 462, 461, 457, 455, 453, 452, 451, 450, 449, - 446, 445, 443, 442, 440, 439, 438, 435, 434, 433, - 432, 431, 430, 429, 427, 426, 425, 424, 423, 422, - 421, 420, 419, 418, 417, 416, 414, 413, 409, 408, - 407, 406, 405, 404, 402, 401, 400, 399, 398, 397, - - 396, 395, 394, 393, 392, 391, 390, 387, 386, 385, - 384, 382, 381, 380, 379, 378, 377, 376, 375, 374, - 373, 372, 369, 368, 366, 365, 364, 363, 362, 361, - 359, 358, 357, 356, 353, 350, 349, 347, 346, 343, - 342, 341, 340, 339, 338, 337, 335, 334, 333, 331, - 328, 327, 326, 325, 324, 323, 321, 318, 317, 316, - 315, 314, 313, 312, 311, 310, 309, 308, 304, 302, - 301, 300, 299, 298, 296, 294, 293, 292, 289, 288, - 287, 286, 285, 284, 282, 280, 279, 278, 277, 275, - 274, 273, 272, 271, 270, 269, 268, 267, 266, 265, - - 263, 261, 260, 259, 258, 257, 256, 254, 253, 252, - 251, 250, 249, 248, 247, 245, 244, 243, 242, 240, - 239, 238, 237, 236, 235, 233, 232, 231, 230, 229, - 228, 227, 226, 225, 224, 223, 222, 221, 220, 219, - 218, 217, 215, 214, 213, 212, 211, 209, 208, 207, - 206, 204, 203, 202, 201, 200, 199, 198, 197, 196, - 195, 194, 193, 192, 191, 190, 189, 188, 187, 186, - 184, 183, 182, 180, 179, 178, 176, 175, 174, 173, - 172, 171, 170, 169, 167, 166, 165, 164, 163, 162, - 161, 160, 159, 158, 157, 155, 154, 153, 152, 151, - - 150, 148, 147, 146, 145, 144, 143, 142, 141, 140, - 139, 138, 137, 136, 134, 132, 131, 130, 129, 128, - 127, 126, 125, 124, 122, 121, 119, 118, 117, 115, - 114, 113, 112, 111, 109, 108, 106, 105, 104, 103, - 102, 101, 100, 99, 97, 96, 95, 94, 93, 92, - 91, 90, 89, 88, 87, 86, 84, 83, 82, 81, - 80, 79, 78, 77, 76, 75, 74, 73, 72, 71, - 69, 68, 67, 65, 64, 63, 56, 54, 53, 52, - 46, 41, 40, 39, 38, 37, 24, 17, 16, 3, - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568, 568, 568, 568, - 568, 568, 568, 568, 568, 568, 568 - } ; - -static yy_state_type yy_last_accepting_state; -static char *yy_last_accepting_cpos; - -/* The intent behind this definition is that it'll catch - * any uses of REJECT which flex missed. - */ -#define REJECT reject_used_but_not_detected -#define yymore() yymore_used_but_not_detected -#define YY_MORE_ADJ 0 -#define YY_RESTORE_YY_MORE_OFFSET -char *yytext; -#line 1 "lexer.lxx" -#define INITIAL 0 -/* -// Filename: lexer.l -// Created by: drose (16Jan99) -// -//////////////////////////////////////////////////////////////////// -*/ -#line 9 "lexer.lxx" -#include "pandabase.h" -#include "lexerDefs.h" -#include "parserDefs.h" -#include "config_egg.h" -#include "parser.h" -#include "indent.h" -#include "pnotify.h" -#include "pmutex.h" -#include "thread.h" - -#include - -extern "C" int eggyywrap(void); // declared below. - -static int yyinput(void); // declared by flex. - - -//////////////////////////////////////////////////////////////////// -// Static variables -//////////////////////////////////////////////////////////////////// - -// This mutex protects all of these global variables. -Mutex egg_lock; - -// We'll increment line_number and col_number as we parse the file, so -// that we can report the position of an error. -static int line_number = 0; -static int col_number = 0; - -// current_line holds as much of the current line as will fit. Its -// only purpose is for printing it out to report an error to the user. -static const int max_error_width = 1024; -static char current_line[max_error_width + 1]; - -static int error_count = 0; -static int warning_count = 0; - -// This is the pointer to the current input stream. -static istream *inp = NULL; - -// This is the name of the egg file we're parsing. We keep it so we -// can print it out for error messages. -static string egg_filename; - -// This is the initial token state returned by the lexer. It allows -// the yacc grammar to start from initial points. -static int initial_token; - -//////////////////////////////////////////////////////////////////// -// Defining the interface to the lexer. -//////////////////////////////////////////////////////////////////// - -void -egg_init_lexer(istream &in, const string &filename) { - inp = ∈ - egg_filename = filename; - line_number = 0; - col_number = 0; - error_count = 0; - warning_count = 0; - initial_token = START_EGG; -} - -void -egg_start_group_body() { - /* Set the initial state to begin within a group_body context, - instead of at the beginning of the egg file. */ - initial_token = START_GROUP_BODY; -} - -void -egg_start_texture_body() { - initial_token = START_TEXTURE_BODY; -} - -void -egg_start_primitive_body() { - initial_token = START_PRIMITIVE_BODY; -} - -int -egg_error_count() { - return error_count; -} - -int -egg_warning_count() { - return warning_count; -} - - -//////////////////////////////////////////////////////////////////// -// Internal support functions. -//////////////////////////////////////////////////////////////////// - -int -eggyywrap(void) { - return 1; -} - -void -eggyyerror(const string &msg) { - if (egg_cat.is_error()) { - ostream &out = egg_cat.error(false); - - out << "\nError"; - if (!egg_filename.empty()) { - out << " in " << egg_filename; - } - out - << " at line " << line_number << ", column " << col_number << ":\n" - << setiosflags(Notify::get_literal_flag()) - << current_line << "\n"; - indent(out, col_number-1) - << "^\n" << msg << "\n\n" - << resetiosflags(Notify::get_literal_flag()) << flush; - } - error_count++; -} - -void -eggyyerror(ostringstream &strm) { - string s = strm.str(); - eggyyerror(s); -} - -void -eggyywarning(const string &msg) { - if (egg_cat.is_warning()) { - ostream &out = egg_cat.warning(false); - - out << "\nWarning"; - if (!egg_filename.empty()) { - out << " in " << egg_filename; - } - out - << " at line " << line_number << ", column " << col_number << ":\n" - << setiosflags(Notify::get_literal_flag()) - << current_line << "\n"; - indent(out, col_number-1) - << "^\n" << msg << "\n\n" - << resetiosflags(Notify::get_literal_flag()) << flush; - } - warning_count++; -} - -void -eggyywarning(ostringstream &strm) { - string s = strm.str(); - eggyywarning(s); -} - -// Now define a function to take input from an istream instead of a -// stdio FILE pointer. This is flex-specific. -static void -input_chars(char *buffer, int &result, int max_size) { - nassertv(inp != NULL); - if (*inp) { - inp->read(buffer, max_size); - result = inp->gcount(); - - if (line_number == 0) { - // This is a special case. If we are reading the very first bit - // from the stream, copy it into the current_line array. This - // is because the \n.* rule below, which fills current_line - // normally, doesn't catch the first line. - int length = min(max_error_width, result); - strncpy(current_line, buffer, length); - current_line[length] = '\0'; - line_number++; - col_number = 0; - - // Truncate it at the newline. - char *end = strchr(current_line, '\n'); - if (end != NULL) { - *end = '\0'; - } - } - - } else { - // End of file or I/O error. - result = 0; - } - Thread::consider_yield(); -} -#undef YY_INPUT -#define YY_INPUT(buffer, result, max_size) input_chars(buffer, result, max_size) - -// read_char reads and returns a single character, incrementing the -// supplied line and column numbers as appropriate. A convenience -// function for the scanning functions below. -static int -read_char(int &line, int &col) { - int c = yyinput(); - if (c == '\n') { - line++; - col = 0; - } else { - col++; - } - return c; -} - -// scan_quoted_string reads a string delimited by quotation marks and -// returns it. -static string -scan_quoted_string() { - string result; - - // We don't touch the current line number and column number during - // scanning, so that if we detect an error while scanning the string - // (e.g. an unterminated string), we'll report the error as - // occurring at the start of the string, not at the end--somewhat - // more convenient for the user. - - // Instead of adjusting the global line_number and col_number - // variables, we'll operate on our own local variables for the - // interim. - int line = line_number; - int col = col_number; - - int c; - c = read_char(line, col); - while (c != '"' && c != EOF) { - result += c; - c = read_char(line, col); - } - - if (c == EOF) { - eggyyerror("This quotation mark is unterminated."); - } - - line_number = line; - col_number = col; - - return result; -} - -// eat_c_comment scans past all characters up until the first */ -// encountered. -static void -eat_c_comment() { - // As above, we'll operate on our own local copies of line_number - // and col_number within this function. - - int line = line_number; - int col = col_number; - - int c, last_c; - - last_c = '\0'; - c = read_char(line, col); - while (c != EOF && !(last_c == '*' && c == '/')) { - if (last_c == '/' && c == '*') { - ostringstream errmsg; - errmsg << "This comment contains a nested /* symbol at line " - << line << ", column " << col-1 << "--possibly unclosed?" - << ends; - eggyywarning(errmsg); - } - last_c = c; - c = read_char(line, col); - } - - if (c == EOF) { - eggyyerror("This comment marker is unclosed."); - } - - line_number = line; - col_number = col; -} - - -// accept() is called below as each piece is pulled off and -// accepted by the lexer; it increments the current column number. -INLINE void accept() { - col_number += yyleng; -} - -#line 1020 "lex.yy.c" - -/* Macros after this point can all be overridden by user definitions in - * section 1. - */ - -#ifndef YY_SKIP_YYWRAP -#ifdef __cplusplus -extern "C" int yywrap YY_PROTO(( void )); -#else -extern int yywrap YY_PROTO(( void )); -#endif -#endif - -#ifndef YY_NO_UNPUT -static void yyunput YY_PROTO(( int c, char *buf_ptr )); -#endif - -#ifndef yytext_ptr -static void yy_flex_strncpy YY_PROTO(( char *, yyconst char *, int )); -#endif - -#ifdef YY_NEED_STRLEN -static int yy_flex_strlen YY_PROTO(( yyconst char * )); -#endif - -#ifndef YY_NO_INPUT -#ifdef __cplusplus -static int yyinput YY_PROTO(( void )); -#else -static int input YY_PROTO(( void )); -#endif -#endif - -#if YY_STACK_USED -static int yy_start_stack_ptr = 0; -static int yy_start_stack_depth = 0; -static int *yy_start_stack = 0; -#ifndef YY_NO_PUSH_STATE -static void yy_push_state YY_PROTO(( int new_state )); -#endif -#ifndef YY_NO_POP_STATE -static void yy_pop_state YY_PROTO(( void )); -#endif -#ifndef YY_NO_TOP_STATE -static int yy_top_state YY_PROTO(( void )); -#endif - -#else -#define YY_NO_PUSH_STATE 1 -#define YY_NO_POP_STATE 1 -#define YY_NO_TOP_STATE 1 -#endif - -#ifdef YY_MALLOC_DECL -YY_MALLOC_DECL -#else -#if __STDC__ -#ifndef __cplusplus -#include -#endif -#else -/* Just try to get by without declaring the routines. This will fail - * miserably on non-ANSI systems for which sizeof(size_t) != sizeof(int) - * or sizeof(void*) != sizeof(int). - */ -#endif -#endif - -/* Amount of stuff to slurp up with each read. */ -#ifndef YY_READ_BUF_SIZE -#define YY_READ_BUF_SIZE 8192 -#endif - -/* Copy whatever the last rule matched to the standard output. */ - -#ifndef ECHO -/* This used to be an fputs(), but since the string might contain NUL's, - * we now use fwrite(). - */ -#define ECHO (void) fwrite( yytext, yyleng, 1, yyout ) -#endif - -/* Gets input and stuffs it into "buf". number of characters read, or YY_NULL, - * is returned in "result". - */ -#ifndef YY_INPUT -#define YY_INPUT(buf,result,max_size) \ - if ( yy_current_buffer->yy_is_interactive ) \ - { \ - int c = '*', n; \ - for ( n = 0; n < max_size && \ - (c = getc( yyin )) != EOF && c != '\n'; ++n ) \ - buf[n] = (char) c; \ - if ( c == '\n' ) \ - buf[n++] = (char) c; \ - if ( c == EOF && ferror( yyin ) ) \ - YY_FATAL_ERROR( "input in flex scanner failed" ); \ - result = n; \ - } \ - else \ - { \ - errno=0; \ - while ( (result = fread(buf, 1, max_size, yyin))==0 && ferror(yyin)) \ - { \ - if( errno != EINTR) \ - { \ - YY_FATAL_ERROR( "input in flex scanner failed" ); \ - break; \ - } \ - errno=0; \ - clearerr(yyin); \ - } \ - } -#endif - -/* No semi-colon after return; correct usage is to write "yyterminate();" - - * we don't want an extra ';' after the "return" because that will cause - * some compilers to complain about unreachable statements. - */ -#ifndef yyterminate -#define yyterminate() return YY_NULL -#endif - -/* Number of entries by which start-condition stack grows. */ -#ifndef YY_START_STACK_INCR -#define YY_START_STACK_INCR 25 -#endif - -/* Report a fatal error. */ -#ifndef YY_FATAL_ERROR -#define YY_FATAL_ERROR(msg) yy_fatal_error( msg ) -#endif - -/* Default declaration of generated scanner - a define so the user can - * easily add parameters. - */ -#ifndef YY_DECL -#define YY_DECL int yylex YY_PROTO(( void )) -#endif - -/* Code executed at the beginning of each rule, after yytext and yyleng - * have been set up. - */ -#ifndef YY_USER_ACTION -#define YY_USER_ACTION -#endif - -/* Code executed at the end of each rule. */ -#ifndef YY_BREAK -#define YY_BREAK break; -#endif - -#define YY_RULE_SETUP \ - YY_USER_ACTION - -YY_DECL - { - register yy_state_type yy_current_state; - register char *yy_cp, *yy_bp; - register int yy_act; - -#line 294 "lexer.lxx" - - - - if (initial_token != 0) { - int t = initial_token; - initial_token = 0; - return t; - } - - -#line 1193 "lex.yy.c" - - if ( yy_init ) - { - yy_init = 0; - -#ifdef YY_USER_INIT - YY_USER_INIT; -#endif - - if ( ! yy_start ) - yy_start = 1; /* first start state */ - - if ( ! yyin ) - yyin = stdin; - - if ( ! yyout ) - yyout = stdout; - - if ( ! yy_current_buffer ) - yy_current_buffer = - yy_create_buffer( yyin, YY_BUF_SIZE ); - - yy_load_buffer_state(); - } - - while ( 1 ) /* loops until end-of-file is reached */ - { - yy_cp = yy_c_buf_p; - - /* Support of yytext. */ - *yy_cp = yy_hold_char; - - /* yy_bp points to the position in yy_ch_buf of the start of - * the current run. - */ - yy_bp = yy_cp; - - yy_current_state = yy_start; -yy_match: - do - { - register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)]; - if ( yy_accept[yy_current_state] ) - { - yy_last_accepting_state = yy_current_state; - yy_last_accepting_cpos = yy_cp; - } - while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) - { - yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 569 ) - yy_c = yy_meta[(unsigned int) yy_c]; - } - yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; - ++yy_cp; - } - while ( yy_base[yy_current_state] != 691 ); - -yy_find_action: - yy_act = yy_accept[yy_current_state]; - if ( yy_act == 0 ) - { /* have to back up */ - yy_cp = yy_last_accepting_cpos; - yy_current_state = yy_last_accepting_state; - yy_act = yy_accept[yy_current_state]; - } - - YY_DO_BEFORE_ACTION; - - -do_action: /* This label is used only to access EOF actions. */ - - - switch ( yy_act ) - { /* beginning of action switch */ - case 0: /* must back up */ - /* undo the effects of YY_DO_BEFORE_ACTION */ - *yy_cp = yy_hold_char; - yy_cp = yy_last_accepting_cpos; - yy_current_state = yy_last_accepting_state; - goto yy_find_action; - -case 1: -YY_RULE_SETUP -#line 304 "lexer.lxx" -{ - // New line. Save a copy of the line so we can print it out for the - // benefit of the user in case we get an error. - - strncpy(current_line, yytext+1, max_error_width); - current_line[max_error_width] = '\0'; - line_number++; - col_number=0; - - // Return the whole line to the lexer, except the newline character, - // which we eat. - yyless(1); -} - YY_BREAK -case 2: -YY_RULE_SETUP -#line 318 "lexer.lxx" -{ - // Eat whitespace. - accept(); -} - YY_BREAK -case 3: -YY_RULE_SETUP -#line 323 "lexer.lxx" -{ - // Eat C++-style comments. - accept(); -} - YY_BREAK -case 4: -YY_RULE_SETUP -#line 328 "lexer.lxx" -{ - // Eat C-style comments. - accept(); - eat_c_comment(); -} - YY_BREAK -case 5: -YY_RULE_SETUP -#line 334 "lexer.lxx" -{ - // Send curly braces as themselves. - accept(); - return eggyytext[0]; -} - YY_BREAK -case 6: -YY_RULE_SETUP -#line 342 "lexer.lxx" -{ - accept(); - return BEZIERCURVE; -} - YY_BREAK -case 7: -YY_RULE_SETUP -#line 346 "lexer.lxx" -{ - accept(); - return BFACE; -} - YY_BREAK -case 8: -YY_RULE_SETUP -#line 350 "lexer.lxx" -{ - accept(); - return BILLBOARD; -} - YY_BREAK -case 9: -YY_RULE_SETUP -#line 354 "lexer.lxx" -{ - accept(); - return BILLBOARDCENTER; -} - YY_BREAK -case 10: -YY_RULE_SETUP -#line 358 "lexer.lxx" -{ - accept(); - return BINORMAL; -} - YY_BREAK -case 11: -YY_RULE_SETUP -#line 362 "lexer.lxx" -{ - accept(); - return BUNDLE; -} - YY_BREAK -case 12: -YY_RULE_SETUP -#line 366 "lexer.lxx" -{ - accept(); - return SCALAR; -} - YY_BREAK -case 13: -YY_RULE_SETUP -#line 370 "lexer.lxx" -{ - accept(); - return CLOSED; -} - YY_BREAK -case 14: -YY_RULE_SETUP -#line 374 "lexer.lxx" -{ - accept(); - return COLLIDE; -} - YY_BREAK -case 15: -YY_RULE_SETUP -#line 378 "lexer.lxx" -{ - accept(); - return COMMENT; -} - YY_BREAK -case 16: -YY_RULE_SETUP -#line 382 "lexer.lxx" -{ - accept(); - return COMPONENT; -} - YY_BREAK -case 17: -YY_RULE_SETUP -#line 386 "lexer.lxx" -{ - accept(); - return COORDSYSTEM; -} - YY_BREAK -case 18: -YY_RULE_SETUP -#line 390 "lexer.lxx" -{ - accept(); - return CV; -} - YY_BREAK -case 19: -YY_RULE_SETUP -#line 394 "lexer.lxx" -{ - accept(); - return DART; -} - YY_BREAK -case 20: -YY_RULE_SETUP -#line 398 "lexer.lxx" -{ - accept(); - return DNORMAL; -} - YY_BREAK -case 21: -YY_RULE_SETUP -#line 402 "lexer.lxx" -{ - accept(); - return DRGBA; -} - YY_BREAK -case 22: -YY_RULE_SETUP -#line 406 "lexer.lxx" -{ - accept(); - return DUV; -} - YY_BREAK -case 23: -YY_RULE_SETUP -#line 410 "lexer.lxx" -{ - accept(); - return DXYZ; -} - YY_BREAK -case 24: -YY_RULE_SETUP -#line 414 "lexer.lxx" -{ - accept(); - return DCS; -} - YY_BREAK -case 25: -YY_RULE_SETUP -#line 418 "lexer.lxx" -{ - accept(); - return DISTANCE; -} - YY_BREAK -case 26: -YY_RULE_SETUP -#line 422 "lexer.lxx" -{ - accept(); - return DTREF; -} - YY_BREAK -case 27: -YY_RULE_SETUP -#line 426 "lexer.lxx" -{ - accept(); - return DYNAMICVERTEXPOOL; -} - YY_BREAK -case 28: -YY_RULE_SETUP -#line 430 "lexer.lxx" -{ - accept(); - return EXTERNAL_FILE; -} - YY_BREAK -case 29: -YY_RULE_SETUP -#line 434 "lexer.lxx" -{ - accept(); - return FLIGHT; -} - YY_BREAK -case 30: -YY_RULE_SETUP -#line 438 "lexer.lxx" -{ - accept(); - return GROUP; -} - YY_BREAK -case 31: -YY_RULE_SETUP -#line 442 "lexer.lxx" -{ - accept(); - return HIP; -} - YY_BREAK -case 32: -YY_RULE_SETUP -#line 446 "lexer.lxx" -{ - accept(); - return INTANGENT; -} - YY_BREAK -case 33: -YY_RULE_SETUP -#line 450 "lexer.lxx" -{ - accept(); - return JOINT; -} - YY_BREAK -case 34: -YY_RULE_SETUP -#line 454 "lexer.lxx" -{ - accept(); - return KNOTS; -} - YY_BREAK -case 35: -YY_RULE_SETUP -#line 458 "lexer.lxx" -{ - accept(); - return INCLUDE; -} - YY_BREAK -case 36: -YY_RULE_SETUP -#line 462 "lexer.lxx" -{ - accept(); - return INSTANCE; -} - YY_BREAK -case 37: -YY_RULE_SETUP -#line 466 "lexer.lxx" -{ - accept(); - return LINE; -} - YY_BREAK -case 38: -YY_RULE_SETUP -#line 470 "lexer.lxx" -{ - accept(); - return LOOP; -} - YY_BREAK -case 39: -YY_RULE_SETUP -#line 474 "lexer.lxx" -{ - accept(); - return MATERIAL; -} - YY_BREAK -case 40: -YY_RULE_SETUP -#line 478 "lexer.lxx" -{ - accept(); - return MATRIX3; -} - YY_BREAK -case 41: -YY_RULE_SETUP -#line 482 "lexer.lxx" -{ - accept(); - return MATRIX4; -} - YY_BREAK -case 42: -YY_RULE_SETUP -#line 486 "lexer.lxx" -{ - accept(); - return MODEL; -} - YY_BREAK -case 43: -YY_RULE_SETUP -#line 490 "lexer.lxx" -{ - accept(); - return MREF; -} - YY_BREAK -case 44: -YY_RULE_SETUP -#line 494 "lexer.lxx" -{ - accept(); - return NORMAL; -} - YY_BREAK -case 45: -YY_RULE_SETUP -#line 498 "lexer.lxx" -{ - accept(); - return NURBSCURVE; -} - YY_BREAK -case 46: -YY_RULE_SETUP -#line 502 "lexer.lxx" -{ - accept(); - return NURBSSURFACE; -} - YY_BREAK -case 47: -YY_RULE_SETUP -#line 506 "lexer.lxx" -{ - accept(); - return OBJECTTYPE; -} - YY_BREAK -case 48: -YY_RULE_SETUP -#line 510 "lexer.lxx" -{ - accept(); - return ORDER; -} - YY_BREAK -case 49: -YY_RULE_SETUP -#line 514 "lexer.lxx" -{ - accept(); - return OUTTANGENT; -} - YY_BREAK -case 50: -YY_RULE_SETUP -#line 518 "lexer.lxx" -{ - accept(); - return POINTLIGHT; -} - YY_BREAK -case 51: -YY_RULE_SETUP -#line 522 "lexer.lxx" -{ - accept(); - return POLYGON; -} - YY_BREAK -case 52: -YY_RULE_SETUP -#line 526 "lexer.lxx" -{ - accept(); - return REF; -} - YY_BREAK -case 53: -YY_RULE_SETUP -#line 530 "lexer.lxx" -{ - accept(); - return RGBA; -} - YY_BREAK -case 54: -YY_RULE_SETUP -#line 534 "lexer.lxx" -{ - accept(); - return ROTATE; -} - YY_BREAK -case 55: -YY_RULE_SETUP -#line 538 "lexer.lxx" -{ - accept(); - return ROTX; -} - YY_BREAK -case 56: -YY_RULE_SETUP -#line 542 "lexer.lxx" -{ - accept(); - return ROTY; -} - YY_BREAK -case 57: -YY_RULE_SETUP -#line 546 "lexer.lxx" -{ - accept(); - return ROTZ; -} - YY_BREAK -case 58: -YY_RULE_SETUP -#line 550 "lexer.lxx" -{ - accept(); - return SANIM; -} - YY_BREAK -case 59: -YY_RULE_SETUP -#line 554 "lexer.lxx" -{ - accept(); - return SCALAR; -} - YY_BREAK -case 60: -YY_RULE_SETUP -#line 558 "lexer.lxx" -{ - accept(); - return SCALE; -} - YY_BREAK -case 61: -YY_RULE_SETUP -#line 562 "lexer.lxx" -{ - accept(); - return SEQUENCE; -} - YY_BREAK -case 62: -YY_RULE_SETUP -#line 566 "lexer.lxx" -{ - accept(); - return SHADING; -} - YY_BREAK -case 63: -YY_RULE_SETUP -#line 570 "lexer.lxx" -{ - accept(); - return SWITCH; -} - YY_BREAK -case 64: -YY_RULE_SETUP -#line 574 "lexer.lxx" -{ - accept(); - return SWITCHCONDITION; -} - YY_BREAK -case 65: -YY_RULE_SETUP -#line 578 "lexer.lxx" -{ - accept(); - return TABLE; -} - YY_BREAK -case 66: -YY_RULE_SETUP -#line 582 "lexer.lxx" -{ - accept(); - return TABLE_V; -} - YY_BREAK -case 67: -YY_RULE_SETUP -#line 586 "lexer.lxx" -{ - accept(); - return TAG; -} - YY_BREAK -case 68: -YY_RULE_SETUP -#line 590 "lexer.lxx" -{ - accept(); - return TANGENT; -} - YY_BREAK -case 69: -YY_RULE_SETUP -#line 594 "lexer.lxx" -{ - accept(); - return TEXLIST; -} - YY_BREAK -case 70: -YY_RULE_SETUP -#line 598 "lexer.lxx" -{ - accept(); - return TEXTURE; -} - YY_BREAK -case 71: -YY_RULE_SETUP -#line 602 "lexer.lxx" -{ - accept(); - return TLENGTHS; -} - YY_BREAK -case 72: -YY_RULE_SETUP -#line 606 "lexer.lxx" -{ - accept(); - return TRANSFORM; -} - YY_BREAK -case 73: -YY_RULE_SETUP -#line 610 "lexer.lxx" -{ - accept(); - return TRANSLATE; -} - YY_BREAK -case 74: -YY_RULE_SETUP -#line 614 "lexer.lxx" -{ - accept(); - return TREF; -} - YY_BREAK -case 75: -YY_RULE_SETUP -#line 618 "lexer.lxx" -{ - accept(); - return TRIANGLEFAN; -} - YY_BREAK -case 76: -YY_RULE_SETUP -#line 622 "lexer.lxx" -{ - accept(); - return TRIANGLESTRIP; -} - YY_BREAK -case 77: -YY_RULE_SETUP -#line 626 "lexer.lxx" -{ - accept(); - return TRIM; -} - YY_BREAK -case 78: -YY_RULE_SETUP -#line 630 "lexer.lxx" -{ - accept(); - return TXT; -} - YY_BREAK -case 79: -YY_RULE_SETUP -#line 634 "lexer.lxx" -{ - accept(); - return UKNOTS; -} - YY_BREAK -case 80: -YY_RULE_SETUP -#line 638 "lexer.lxx" -{ - accept(); - return UKNOTS; -} - YY_BREAK -case 81: -YY_RULE_SETUP -#line 642 "lexer.lxx" -{ - accept(); - return UV; -} - YY_BREAK -case 82: -YY_RULE_SETUP -#line 646 "lexer.lxx" -{ - accept(); - return VKNOTS; -} - YY_BREAK -case 83: -YY_RULE_SETUP -#line 650 "lexer.lxx" -{ - accept(); - return VKNOTS; -} - YY_BREAK -case 84: -YY_RULE_SETUP -#line 654 "lexer.lxx" -{ - accept(); - return VERTEX; -} - YY_BREAK -case 85: -YY_RULE_SETUP -#line 658 "lexer.lxx" -{ - accept(); - return VERTEXANIM; -} - YY_BREAK -case 86: -YY_RULE_SETUP -#line 662 "lexer.lxx" -{ - accept(); - return VERTEXPOOL; -} - YY_BREAK -case 87: -YY_RULE_SETUP -#line 666 "lexer.lxx" -{ - accept(); - return VERTEXREF; -} - YY_BREAK -case 88: -YY_RULE_SETUP -#line 670 "lexer.lxx" -{ - accept(); - return XFMANIM; -} - YY_BREAK -case 89: -YY_RULE_SETUP -#line 674 "lexer.lxx" -{ - accept(); - return XFMSANIM; -} - YY_BREAK -case 90: -YY_RULE_SETUP -#line 681 "lexer.lxx" -{ - // An integer or floating-point number. - accept(); - eggyylval._number = atof(eggyytext); - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 91: -YY_RULE_SETUP -#line 689 "lexer.lxx" -{ - // A hexadecimal integer number. - accept(); - eggyylval._ulong = strtoul(yytext+2, NULL, 16); - eggyylval._string = yytext; - return EGG_ULONG; -} - YY_BREAK -case 92: -YY_RULE_SETUP -#line 697 "lexer.lxx" -{ - // A binary integer number. - accept(); - eggyylval._ulong = strtoul(yytext+2, NULL, 2); - eggyylval._string = yytext; - return EGG_ULONG; -} - YY_BREAK -case 93: -YY_RULE_SETUP -#line 705 "lexer.lxx" -{ - // not-a-number. These sometimes show up in egg files accidentally. - accept(); - memset(&eggyylval._number, 0, sizeof(eggyylval._number)); - *(unsigned long *)&eggyylval._number = strtoul(yytext+3, NULL, 0); - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 94: -YY_RULE_SETUP -#line 714 "lexer.lxx" -{ - // infinity. As above. - accept(); - eggyylval._number = HUGE_VAL; - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 95: -YY_RULE_SETUP -#line 722 "lexer.lxx" -{ - // minus infinity. As above. - accept(); - eggyylval._number = -HUGE_VAL; - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 96: -YY_RULE_SETUP -#line 730 "lexer.lxx" -{ - // infinity, on Win32. As above. - accept(); - eggyylval._number = HUGE_VAL; - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 97: -YY_RULE_SETUP -#line 738 "lexer.lxx" -{ - // minus infinity, on Win32. As above. - accept(); - eggyylval._number = -HUGE_VAL; - eggyylval._string = yytext; - return EGG_NUMBER; -} - YY_BREAK -case 98: -YY_RULE_SETUP -#line 747 "lexer.lxx" -{ - // Quoted string. - accept(); - eggyylval._string = scan_quoted_string(); - return EGG_STRING; -} - YY_BREAK -case 99: -YY_RULE_SETUP -#line 754 "lexer.lxx" -{ - // Unquoted string. - accept(); - eggyylval._string = yytext; - return EGG_STRING; -} - YY_BREAK -case 100: -YY_RULE_SETUP -#line 760 "lexer.lxx" -ECHO; - YY_BREAK -#line 2113 "lex.yy.c" -case YY_STATE_EOF(INITIAL): - yyterminate(); - - case YY_END_OF_BUFFER: - { - /* Amount of text matched not including the EOB char. */ - int yy_amount_of_matched_text = (int) (yy_cp - yytext_ptr) - 1; - - /* Undo the effects of YY_DO_BEFORE_ACTION. */ - *yy_cp = yy_hold_char; - YY_RESTORE_YY_MORE_OFFSET - - if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_NEW ) - { - /* We're scanning a new file or input source. It's - * possible that this happened because the user - * just pointed yyin at a new source and called - * yylex(). If so, then we have to assure - * consistency between yy_current_buffer and our - * globals. Here is the right place to do so, because - * this is the first action (other than possibly a - * back-up) that will match for the new input source. - */ - yy_n_chars = yy_current_buffer->yy_n_chars; - yy_current_buffer->yy_input_file = yyin; - yy_current_buffer->yy_buffer_status = YY_BUFFER_NORMAL; - } - - /* Note that here we test for yy_c_buf_p "<=" to the position - * of the first EOB in the buffer, since yy_c_buf_p will - * already have been incremented past the NUL character - * (since all states make transitions on EOB to the - * end-of-buffer state). Contrast this with the test - * in input(). - */ - if ( yy_c_buf_p <= &yy_current_buffer->yy_ch_buf[yy_n_chars] ) - { /* This was really a NUL. */ - yy_state_type yy_next_state; - - yy_c_buf_p = yytext_ptr + yy_amount_of_matched_text; - - yy_current_state = yy_get_previous_state(); - - /* Okay, we're now positioned to make the NUL - * transition. We couldn't have - * yy_get_previous_state() go ahead and do it - * for us because it doesn't know how to deal - * with the possibility of jamming (and we don't - * want to build jamming into it because then it - * will run more slowly). - */ - - yy_next_state = yy_try_NUL_trans( yy_current_state ); - - yy_bp = yytext_ptr + YY_MORE_ADJ; - - if ( yy_next_state ) - { - /* Consume the NUL. */ - yy_cp = ++yy_c_buf_p; - yy_current_state = yy_next_state; - goto yy_match; - } - - else - { - yy_cp = yy_c_buf_p; - goto yy_find_action; - } - } - - else switch ( yy_get_next_buffer() ) - { - case EOB_ACT_END_OF_FILE: - { - yy_did_buffer_switch_on_eof = 0; - - if ( yywrap() ) - { - /* Note: because we've taken care in - * yy_get_next_buffer() to have set up - * yytext, we can now set up - * yy_c_buf_p so that if some total - * hoser (like flex itself) wants to - * call the scanner after we return the - * YY_NULL, it'll still work - another - * YY_NULL will get returned. - */ - yy_c_buf_p = yytext_ptr + YY_MORE_ADJ; - - yy_act = YY_STATE_EOF(YY_START); - goto do_action; - } - - else - { - if ( ! yy_did_buffer_switch_on_eof ) - YY_NEW_FILE; - } - break; - } - - case EOB_ACT_CONTINUE_SCAN: - yy_c_buf_p = - yytext_ptr + yy_amount_of_matched_text; - - yy_current_state = yy_get_previous_state(); - - yy_cp = yy_c_buf_p; - yy_bp = yytext_ptr + YY_MORE_ADJ; - goto yy_match; - - case EOB_ACT_LAST_MATCH: - yy_c_buf_p = - &yy_current_buffer->yy_ch_buf[yy_n_chars]; - - yy_current_state = yy_get_previous_state(); - - yy_cp = yy_c_buf_p; - yy_bp = yytext_ptr + YY_MORE_ADJ; - goto yy_find_action; - } - break; - } - - default: - YY_FATAL_ERROR( - "fatal flex scanner internal error--no action found" ); - } /* end of action switch */ - } /* end of scanning one token */ - } /* end of yylex */ - - -/* yy_get_next_buffer - try to read in a new buffer - * - * Returns a code representing an action: - * EOB_ACT_LAST_MATCH - - * EOB_ACT_CONTINUE_SCAN - continue scanning from current position - * EOB_ACT_END_OF_FILE - end of file - */ - -static int yy_get_next_buffer() - { - register char *dest = yy_current_buffer->yy_ch_buf; - register char *source = yytext_ptr; - register int number_to_move, i; - int ret_val; - - if ( yy_c_buf_p > &yy_current_buffer->yy_ch_buf[yy_n_chars + 1] ) - YY_FATAL_ERROR( - "fatal flex scanner internal error--end of buffer missed" ); - - if ( yy_current_buffer->yy_fill_buffer == 0 ) - { /* Don't try to fill the buffer, so this is an EOF. */ - if ( yy_c_buf_p - yytext_ptr - YY_MORE_ADJ == 1 ) - { - /* We matched a single character, the EOB, so - * treat this as a final EOF. - */ - return EOB_ACT_END_OF_FILE; - } - - else - { - /* We matched some text prior to the EOB, first - * process it. - */ - return EOB_ACT_LAST_MATCH; - } - } - - /* Try to read more data. */ - - /* First move last chars to start of buffer. */ - number_to_move = (int) (yy_c_buf_p - yytext_ptr) - 1; - - for ( i = 0; i < number_to_move; ++i ) - *(dest++) = *(source++); - - if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_EOF_PENDING ) - /* don't do the read, it's not guaranteed to return an EOF, - * just force an EOF - */ - yy_current_buffer->yy_n_chars = yy_n_chars = 0; - - else - { - int num_to_read = - yy_current_buffer->yy_buf_size - number_to_move - 1; - - while ( num_to_read <= 0 ) - { /* Not enough room in the buffer - grow it. */ -#ifdef YY_USES_REJECT - YY_FATAL_ERROR( -"input buffer overflow, can't enlarge buffer because scanner uses REJECT" ); -#else - - /* just a shorter name for the current buffer */ - YY_BUFFER_STATE b = yy_current_buffer; - - int yy_c_buf_p_offset = - (int) (yy_c_buf_p - b->yy_ch_buf); - - if ( b->yy_is_our_buffer ) - { - int new_size = b->yy_buf_size * 2; - - if ( new_size <= 0 ) - b->yy_buf_size += b->yy_buf_size / 8; - else - b->yy_buf_size *= 2; - - b->yy_ch_buf = (char *) - /* Include room in for 2 EOB chars. */ - yy_flex_realloc( (void *) b->yy_ch_buf, - b->yy_buf_size + 2 ); - } - else - /* Can't grow it, we don't own it. */ - b->yy_ch_buf = 0; - - if ( ! b->yy_ch_buf ) - YY_FATAL_ERROR( - "fatal error - scanner input buffer overflow" ); - - yy_c_buf_p = &b->yy_ch_buf[yy_c_buf_p_offset]; - - num_to_read = yy_current_buffer->yy_buf_size - - number_to_move - 1; -#endif - } - - if ( num_to_read > YY_READ_BUF_SIZE ) - num_to_read = YY_READ_BUF_SIZE; - - /* Read in more data. */ - YY_INPUT( (&yy_current_buffer->yy_ch_buf[number_to_move]), - yy_n_chars, num_to_read ); - - yy_current_buffer->yy_n_chars = yy_n_chars; - } - - if ( yy_n_chars == 0 ) - { - if ( number_to_move == YY_MORE_ADJ ) - { - ret_val = EOB_ACT_END_OF_FILE; - yyrestart( yyin ); - } - - else - { - ret_val = EOB_ACT_LAST_MATCH; - yy_current_buffer->yy_buffer_status = - YY_BUFFER_EOF_PENDING; - } - } - - else - ret_val = EOB_ACT_CONTINUE_SCAN; - - yy_n_chars += number_to_move; - yy_current_buffer->yy_ch_buf[yy_n_chars] = YY_END_OF_BUFFER_CHAR; - yy_current_buffer->yy_ch_buf[yy_n_chars + 1] = YY_END_OF_BUFFER_CHAR; - - yytext_ptr = &yy_current_buffer->yy_ch_buf[0]; - - return ret_val; - } - - -/* yy_get_previous_state - get the state just before the EOB char was reached */ - -static yy_state_type yy_get_previous_state() - { - register yy_state_type yy_current_state; - register char *yy_cp; - - yy_current_state = yy_start; - - for ( yy_cp = yytext_ptr + YY_MORE_ADJ; yy_cp < yy_c_buf_p; ++yy_cp ) - { - register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1); - if ( yy_accept[yy_current_state] ) - { - yy_last_accepting_state = yy_current_state; - yy_last_accepting_cpos = yy_cp; - } - while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) - { - yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 569 ) - yy_c = yy_meta[(unsigned int) yy_c]; - } - yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; - } - - return yy_current_state; - } - - -/* yy_try_NUL_trans - try to make a transition on the NUL character - * - * synopsis - * next_state = yy_try_NUL_trans( current_state ); - */ - -#ifdef YY_USE_PROTOS -static yy_state_type yy_try_NUL_trans( yy_state_type yy_current_state ) -#else -static yy_state_type yy_try_NUL_trans( yy_current_state ) -yy_state_type yy_current_state; -#endif - { - register int yy_is_jam; - register char *yy_cp = yy_c_buf_p; - - register YY_CHAR yy_c = 1; - if ( yy_accept[yy_current_state] ) - { - yy_last_accepting_state = yy_current_state; - yy_last_accepting_cpos = yy_cp; - } - while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) - { - yy_current_state = (int) yy_def[yy_current_state]; - if ( yy_current_state >= 569 ) - yy_c = yy_meta[(unsigned int) yy_c]; - } - yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; - yy_is_jam = (yy_current_state == 568); - - return yy_is_jam ? 0 : yy_current_state; - } - - -#ifndef YY_NO_UNPUT -#ifdef YY_USE_PROTOS -static void yyunput( int c, register char *yy_bp ) -#else -static void yyunput( c, yy_bp ) -int c; -register char *yy_bp; -#endif - { - register char *yy_cp = yy_c_buf_p; - - /* undo effects of setting up yytext */ - *yy_cp = yy_hold_char; - - if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 ) - { /* need to shift things up to make room */ - /* +2 for EOB chars. */ - register int number_to_move = yy_n_chars + 2; - register char *dest = &yy_current_buffer->yy_ch_buf[ - yy_current_buffer->yy_buf_size + 2]; - register char *source = - &yy_current_buffer->yy_ch_buf[number_to_move]; - - while ( source > yy_current_buffer->yy_ch_buf ) - *--dest = *--source; - - yy_cp += (int) (dest - source); - yy_bp += (int) (dest - source); - yy_current_buffer->yy_n_chars = - yy_n_chars = yy_current_buffer->yy_buf_size; - - if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 ) - YY_FATAL_ERROR( "flex scanner push-back overflow" ); - } - - *--yy_cp = (char) c; - - - yytext_ptr = yy_bp; - yy_hold_char = *yy_cp; - yy_c_buf_p = yy_cp; - } -#endif /* ifndef YY_NO_UNPUT */ - - -#ifdef __cplusplus -static int yyinput() -#else -static int input() -#endif - { - int c; - - *yy_c_buf_p = yy_hold_char; - - if ( *yy_c_buf_p == YY_END_OF_BUFFER_CHAR ) - { - /* yy_c_buf_p now points to the character we want to return. - * If this occurs *before* the EOB characters, then it's a - * valid NUL; if not, then we've hit the end of the buffer. - */ - if ( yy_c_buf_p < &yy_current_buffer->yy_ch_buf[yy_n_chars] ) - /* This was really a NUL. */ - *yy_c_buf_p = '\0'; - - else - { /* need more input */ - int offset = yy_c_buf_p - yytext_ptr; - ++yy_c_buf_p; - - switch ( yy_get_next_buffer() ) - { - case EOB_ACT_LAST_MATCH: - /* This happens because yy_g_n_b() - * sees that we've accumulated a - * token and flags that we need to - * try matching the token before - * proceeding. But for input(), - * there's no matching to consider. - * So convert the EOB_ACT_LAST_MATCH - * to EOB_ACT_END_OF_FILE. - */ - - /* Reset buffer status. */ - yyrestart( yyin ); - - /* fall through */ - - case EOB_ACT_END_OF_FILE: - { - if ( yywrap() ) - return EOF; - - if ( ! yy_did_buffer_switch_on_eof ) - YY_NEW_FILE; -#ifdef __cplusplus - return yyinput(); -#else - return input(); -#endif - } - - case EOB_ACT_CONTINUE_SCAN: - yy_c_buf_p = yytext_ptr + offset; - break; - } - } - } - - c = *(unsigned char *) yy_c_buf_p; /* cast for 8-bit char's */ - *yy_c_buf_p = '\0'; /* preserve yytext */ - yy_hold_char = *++yy_c_buf_p; - - - return c; - } - - -#ifdef YY_USE_PROTOS -void yyrestart( FILE *input_file ) -#else -void yyrestart( input_file ) -FILE *input_file; -#endif - { - if ( ! yy_current_buffer ) - yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); - - yy_init_buffer( yy_current_buffer, input_file ); - yy_load_buffer_state(); - } - - -#ifdef YY_USE_PROTOS -void yy_switch_to_buffer( YY_BUFFER_STATE new_buffer ) -#else -void yy_switch_to_buffer( new_buffer ) -YY_BUFFER_STATE new_buffer; -#endif - { - if ( yy_current_buffer == new_buffer ) - return; - - if ( yy_current_buffer ) - { - /* Flush out information for old buffer. */ - *yy_c_buf_p = yy_hold_char; - yy_current_buffer->yy_buf_pos = yy_c_buf_p; - yy_current_buffer->yy_n_chars = yy_n_chars; - } - - yy_current_buffer = new_buffer; - yy_load_buffer_state(); - - /* We don't actually know whether we did this switch during - * EOF (yywrap()) processing, but the only time this flag - * is looked at is after yywrap() is called, so it's safe - * to go ahead and always set it. - */ - yy_did_buffer_switch_on_eof = 1; - } - - -#ifdef YY_USE_PROTOS -void yy_load_buffer_state( void ) -#else -void yy_load_buffer_state() -#endif - { - yy_n_chars = yy_current_buffer->yy_n_chars; - yytext_ptr = yy_c_buf_p = yy_current_buffer->yy_buf_pos; - yyin = yy_current_buffer->yy_input_file; - yy_hold_char = *yy_c_buf_p; - } - - -#ifdef YY_USE_PROTOS -YY_BUFFER_STATE yy_create_buffer( FILE *file, int size ) -#else -YY_BUFFER_STATE yy_create_buffer( file, size ) -FILE *file; -int size; -#endif - { - YY_BUFFER_STATE b; - - b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) ); - if ( ! b ) - YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); - - b->yy_buf_size = size; - - /* yy_ch_buf has to be 2 characters longer than the size given because - * we need to put in 2 end-of-buffer characters. - */ - b->yy_ch_buf = (char *) yy_flex_alloc( b->yy_buf_size + 2 ); - if ( ! b->yy_ch_buf ) - YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); - - b->yy_is_our_buffer = 1; - - yy_init_buffer( b, file ); - - return b; - } - - -#ifdef YY_USE_PROTOS -void yy_delete_buffer( YY_BUFFER_STATE b ) -#else -void yy_delete_buffer( b ) -YY_BUFFER_STATE b; -#endif - { - if ( ! b ) - return; - - if ( b == yy_current_buffer ) - yy_current_buffer = (YY_BUFFER_STATE) 0; - - if ( b->yy_is_our_buffer ) - yy_flex_free( (void *) b->yy_ch_buf ); - - yy_flex_free( (void *) b ); - } - - -#ifndef _WIN32 -#else -#ifndef YY_ALWAYS_INTERACTIVE -#ifndef YY_NEVER_INTERACTIVE -extern int isatty YY_PROTO(( int )); -#endif -#endif -#endif - -#ifdef YY_USE_PROTOS -void yy_init_buffer( YY_BUFFER_STATE b, FILE *file ) -#else -void yy_init_buffer( b, file ) -YY_BUFFER_STATE b; -FILE *file; -#endif - - - { - yy_flush_buffer( b ); - - b->yy_input_file = file; - b->yy_fill_buffer = 1; - -#if YY_ALWAYS_INTERACTIVE - b->yy_is_interactive = 1; -#else -#if YY_NEVER_INTERACTIVE - b->yy_is_interactive = 0; -#else - b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0; -#endif -#endif - } - - -#ifdef YY_USE_PROTOS -void yy_flush_buffer( YY_BUFFER_STATE b ) -#else -void yy_flush_buffer( b ) -YY_BUFFER_STATE b; -#endif - - { - if ( ! b ) - return; - - b->yy_n_chars = 0; - - /* We always need two end-of-buffer characters. The first causes - * a transition to the end-of-buffer state. The second causes - * a jam in that state. - */ - b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR; - b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR; - - b->yy_buf_pos = &b->yy_ch_buf[0]; - - b->yy_at_bol = 1; - b->yy_buffer_status = YY_BUFFER_NEW; - - if ( b == yy_current_buffer ) - yy_load_buffer_state(); - } - - -#ifndef YY_NO_SCAN_BUFFER -#ifdef YY_USE_PROTOS -YY_BUFFER_STATE yy_scan_buffer( char *base, yy_size_t size ) -#else -YY_BUFFER_STATE yy_scan_buffer( base, size ) -char *base; -yy_size_t size; -#endif - { - YY_BUFFER_STATE b; - - if ( size < 2 || - base[size-2] != YY_END_OF_BUFFER_CHAR || - base[size-1] != YY_END_OF_BUFFER_CHAR ) - /* They forgot to leave room for the EOB's. */ - return 0; - - b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) ); - if ( ! b ) - YY_FATAL_ERROR( "out of dynamic memory in yy_scan_buffer()" ); - - b->yy_buf_size = size - 2; /* "- 2" to take care of EOB's */ - b->yy_buf_pos = b->yy_ch_buf = base; - b->yy_is_our_buffer = 0; - b->yy_input_file = 0; - b->yy_n_chars = b->yy_buf_size; - b->yy_is_interactive = 0; - b->yy_at_bol = 1; - b->yy_fill_buffer = 0; - b->yy_buffer_status = YY_BUFFER_NEW; - - yy_switch_to_buffer( b ); - - return b; - } -#endif - - -#ifndef YY_NO_SCAN_STRING -#ifdef YY_USE_PROTOS -YY_BUFFER_STATE yy_scan_string( yyconst char *yy_str ) -#else -YY_BUFFER_STATE yy_scan_string( yy_str ) -yyconst char *yy_str; -#endif - { - int len; - for ( len = 0; yy_str[len]; ++len ) - ; - - return yy_scan_bytes( yy_str, len ); - } -#endif - - -#ifndef YY_NO_SCAN_BYTES -#ifdef YY_USE_PROTOS -YY_BUFFER_STATE yy_scan_bytes( yyconst char *bytes, int len ) -#else -YY_BUFFER_STATE yy_scan_bytes( bytes, len ) -yyconst char *bytes; -int len; -#endif - { - YY_BUFFER_STATE b; - char *buf; - yy_size_t n; - int i; - - /* Get memory for full buffer, including space for trailing EOB's. */ - n = len + 2; - buf = (char *) yy_flex_alloc( n ); - if ( ! buf ) - YY_FATAL_ERROR( "out of dynamic memory in yy_scan_bytes()" ); - - for ( i = 0; i < len; ++i ) - buf[i] = bytes[i]; - - buf[len] = buf[len+1] = YY_END_OF_BUFFER_CHAR; - - b = yy_scan_buffer( buf, n ); - if ( ! b ) - YY_FATAL_ERROR( "bad buffer in yy_scan_bytes()" ); - - /* It's okay to grow etc. this buffer, and we should throw it - * away when we're done. - */ - b->yy_is_our_buffer = 1; - - return b; - } -#endif - - -#ifndef YY_NO_PUSH_STATE -#ifdef YY_USE_PROTOS -static void yy_push_state( int new_state ) -#else -static void yy_push_state( new_state ) -int new_state; -#endif - { - if ( yy_start_stack_ptr >= yy_start_stack_depth ) - { - yy_size_t new_size; - - yy_start_stack_depth += YY_START_STACK_INCR; - new_size = yy_start_stack_depth * sizeof( int ); - - if ( ! yy_start_stack ) - yy_start_stack = (int *) yy_flex_alloc( new_size ); - - else - yy_start_stack = (int *) yy_flex_realloc( - (void *) yy_start_stack, new_size ); - - if ( ! yy_start_stack ) - YY_FATAL_ERROR( - "out of memory expanding start-condition stack" ); - } - - yy_start_stack[yy_start_stack_ptr++] = YY_START; - - BEGIN(new_state); - } -#endif - - -#ifndef YY_NO_POP_STATE -static void yy_pop_state() - { - if ( --yy_start_stack_ptr < 0 ) - YY_FATAL_ERROR( "start-condition stack underflow" ); - - BEGIN(yy_start_stack[yy_start_stack_ptr]); - } -#endif - - -#ifndef YY_NO_TOP_STATE -static int yy_top_state() - { - return yy_start_stack[yy_start_stack_ptr - 1]; - } -#endif - -#ifndef YY_EXIT_FAILURE -#define YY_EXIT_FAILURE 2 -#endif - -#ifdef YY_USE_PROTOS -static void yy_fatal_error( yyconst char msg[] ) -#else -static void yy_fatal_error( msg ) -char msg[]; -#endif - { - (void) fprintf( stderr, "%s\n", msg ); - exit( YY_EXIT_FAILURE ); - } - - - -/* Redefine yyless() so it works in section 3 code. */ - -#undef yyless -#define yyless(n) \ - do \ - { \ - /* Undo effects of setting up yytext. */ \ - yytext[yyleng] = yy_hold_char; \ - yy_c_buf_p = yytext + n; \ - yy_hold_char = *yy_c_buf_p; \ - *yy_c_buf_p = '\0'; \ - yyleng = n; \ - } \ - while ( 0 ) - - -/* Internal utility routines. */ - -#ifndef yytext_ptr -#ifdef YY_USE_PROTOS -static void yy_flex_strncpy( char *s1, yyconst char *s2, int n ) -#else -static void yy_flex_strncpy( s1, s2, n ) -char *s1; -yyconst char *s2; -int n; -#endif - { - register int i; - for ( i = 0; i < n; ++i ) - s1[i] = s2[i]; - } -#endif - -#ifdef YY_NEED_STRLEN -#ifdef YY_USE_PROTOS -static int yy_flex_strlen( yyconst char *s ) -#else -static int yy_flex_strlen( s ) -yyconst char *s; -#endif - { - register int n; - for ( n = 0; s[n]; ++n ) - ; - - return n; - } -#endif - - -#ifdef YY_USE_PROTOS -static void *yy_flex_alloc( yy_size_t size ) -#else -static void *yy_flex_alloc( size ) -yy_size_t size; -#endif - { - return (void *) malloc( size ); - } - -#ifdef YY_USE_PROTOS -static void *yy_flex_realloc( void *ptr, yy_size_t size ) -#else -static void *yy_flex_realloc( ptr, size ) -void *ptr; -yy_size_t size; -#endif - { - /* The cast to (char *) in the following accommodates both - * implementations that use char* generic pointers, and those - * that use void* generic pointers. It works with the latter - * because both ANSI C and C++ allow castless assignment from - * any pointer type to void*, and deal with argument conversions - * as though doing an assignment. - */ - return (void *) realloc( (char *) ptr, size ); - } - -#ifdef YY_USE_PROTOS -static void yy_flex_free( void *ptr ) -#else -static void yy_flex_free( ptr ) -void *ptr; -#endif - { - free( ptr ); - } - -#if YY_MAIN -int main() - { - yylex(); - return 0; - } -#endif -#line 760 "lexer.lxx" +#define yy_create_buffer eggyy_create_buffer +#define yy_delete_buffer eggyy_delete_buffer +#define yy_scan_buffer eggyy_scan_buffer +#define yy_scan_string eggyy_scan_string +#define yy_scan_bytes eggyy_scan_bytes +#define yy_flex_debug eggyy_flex_debug +#define yy_init_buffer eggyy_init_buffer +#define yy_flush_buffer eggyy_flush_buffer +#define yy_load_buffer_state eggyy_load_buffer_state +#define yy_switch_to_buffer eggyy_switch_to_buffer +#define yyin eggyyin +#define yyleng eggyyleng +#define yylex eggyylex +#define yyout eggyyout +#define yyrestart eggyyrestart +#define yytext eggyytext +#define yywrap eggyywrap + +#line 20 "lex.yy.c" +/* A lexical scanner generated by flex */ + +/* Scanner skeleton version: + * $Header$ + */ + +#define FLEX_SCANNER +#define YY_FLEX_MAJOR_VERSION 2 +#define YY_FLEX_MINOR_VERSION 5 + +#include + + +/* cfront 1.2 defines "c_plusplus" instead of "__cplusplus" */ +#ifdef c_plusplus +#ifndef __cplusplus +#define __cplusplus +#endif +#endif + + +#ifdef __cplusplus + +#include + +/* Use prototypes in function declarations. */ +#define YY_USE_PROTOS + +/* The "const" storage-class-modifier is valid. */ +#define YY_USE_CONST + +#else /* ! __cplusplus */ + +#if __STDC__ + +#define YY_USE_PROTOS +#define YY_USE_CONST + +#endif /* __STDC__ */ +#endif /* ! __cplusplus */ + +#ifdef __TURBOC__ + #pragma warn -rch + #pragma warn -use +#include +#include +#define YY_USE_CONST +#define YY_USE_PROTOS +#endif + +#ifdef YY_USE_CONST +#define yyconst const +#else +#define yyconst +#endif + + +#ifdef YY_USE_PROTOS +#define YY_PROTO(proto) proto +#else +#define YY_PROTO(proto) () +#endif + +/* Returned upon end-of-file. */ +#define YY_NULL 0 + +/* Promotes a possibly negative, possibly signed char to an unsigned + * integer for use as an array index. If the signed char is negative, + * we want to instead treat it as an 8-bit unsigned char, hence the + * double cast. + */ +#define YY_SC_TO_UI(c) ((unsigned int) (unsigned char) c) + +/* Enter a start condition. This macro really ought to take a parameter, + * but we do it the disgusting crufty way forced on us by the ()-less + * definition of BEGIN. + */ +#define BEGIN yy_start = 1 + 2 * + +/* Translate the current start state into a value that can be later handed + * to BEGIN to return to the state. The YYSTATE alias is for lex + * compatibility. + */ +#define YY_START ((yy_start - 1) / 2) +#define YYSTATE YY_START + +/* Action number for EOF rule of a given start state. */ +#define YY_STATE_EOF(state) (YY_END_OF_BUFFER + state + 1) + +/* Special action meaning "start processing a new file". */ +#define YY_NEW_FILE yyrestart( yyin ) + +#define YY_END_OF_BUFFER_CHAR 0 + +/* Size of default input buffer. */ +#define YY_BUF_SIZE 16384 + +typedef struct yy_buffer_state *YY_BUFFER_STATE; + +extern int yyleng; +extern FILE *yyin, *yyout; + +#define EOB_ACT_CONTINUE_SCAN 0 +#define EOB_ACT_END_OF_FILE 1 +#define EOB_ACT_LAST_MATCH 2 + +/* The funky do-while in the following #define is used to turn the definition + * int a single C statement (which needs a semi-colon terminator). This + * avoids problems with code like: + * + * if ( condition_holds ) + * yyless( 5 ); + * else + * do_something_else(); + * + * Prior to using the do-while the compiler would get upset at the + * "else" because it interpreted the "if" statement as being all + * done when it reached the ';' after the yyless() call. + */ + +/* Return all but the first 'n' matched characters back to the input stream. */ + +#define yyless(n) \ + do \ + { \ + /* Undo effects of setting up yytext. */ \ + *yy_cp = yy_hold_char; \ + YY_RESTORE_YY_MORE_OFFSET \ + yy_c_buf_p = yy_cp = yy_bp + n - YY_MORE_ADJ; \ + YY_DO_BEFORE_ACTION; /* set up yytext again */ \ + } \ + while ( 0 ) + +#define unput(c) yyunput( c, yytext_ptr ) + +/* The following is because we cannot portably get our hands on size_t + * (without autoconf's help, which isn't available because we want + * flex-generated scanners to compile on their own). + */ +typedef unsigned int yy_size_t; + + +struct yy_buffer_state + { + FILE *yy_input_file; + + char *yy_ch_buf; /* input buffer */ + char *yy_buf_pos; /* current position in input buffer */ + + /* Size of input buffer in bytes, not including room for EOB + * characters. + */ + yy_size_t yy_buf_size; + + /* Number of characters read into yy_ch_buf, not including EOB + * characters. + */ + int yy_n_chars; + + /* Whether we "own" the buffer - i.e., we know we created it, + * and can realloc() it to grow it, and should free() it to + * delete it. + */ + int yy_is_our_buffer; + + /* Whether this is an "interactive" input source; if so, and + * if we're using stdio for input, then we want to use getc() + * instead of fread(), to make sure we stop fetching input after + * each newline. + */ + int yy_is_interactive; + + /* Whether we're considered to be at the beginning of a line. + * If so, '^' rules will be active on the next match, otherwise + * not. + */ + int yy_at_bol; + + /* Whether to try to fill the input buffer when we reach the + * end of it. + */ + int yy_fill_buffer; + + int yy_buffer_status; +#define YY_BUFFER_NEW 0 +#define YY_BUFFER_NORMAL 1 + /* When an EOF's been seen but there's still some text to process + * then we mark the buffer as YY_EOF_PENDING, to indicate that we + * shouldn't try reading from the input source any more. We might + * still have a bunch of tokens to match, though, because of + * possible backing-up. + * + * When we actually see the EOF, we change the status to "new" + * (via yyrestart()), so that the user can continue scanning by + * just pointing yyin at a new input file. + */ +#define YY_BUFFER_EOF_PENDING 2 + }; + +static YY_BUFFER_STATE yy_current_buffer = 0; + +/* We provide macros for accessing buffer states in case in the + * future we want to put the buffer states in a more general + * "scanner state". + */ +#define YY_CURRENT_BUFFER yy_current_buffer + + +/* yy_hold_char holds the character lost when yytext is formed. */ +static char yy_hold_char; + +static int yy_n_chars; /* number of characters read into yy_ch_buf */ + + +int yyleng; + +/* Points to current character in buffer. */ +static char *yy_c_buf_p = (char *) 0; +static int yy_init = 1; /* whether we need to initialize */ +static int yy_start = 0; /* start state number */ + +/* Flag which is used to allow yywrap()'s to do buffer switches + * instead of setting up a fresh yyin. A bit of a hack ... + */ +static int yy_did_buffer_switch_on_eof; + +void yyrestart YY_PROTO(( FILE *input_file )); + +void yy_switch_to_buffer YY_PROTO(( YY_BUFFER_STATE new_buffer )); +void yy_load_buffer_state YY_PROTO(( void )); +YY_BUFFER_STATE yy_create_buffer YY_PROTO(( FILE *file, int size )); +void yy_delete_buffer YY_PROTO(( YY_BUFFER_STATE b )); +void yy_init_buffer YY_PROTO(( YY_BUFFER_STATE b, FILE *file )); +void yy_flush_buffer YY_PROTO(( YY_BUFFER_STATE b )); +#define YY_FLUSH_BUFFER yy_flush_buffer( yy_current_buffer ) + +YY_BUFFER_STATE yy_scan_buffer YY_PROTO(( char *base, yy_size_t size )); +YY_BUFFER_STATE yy_scan_string YY_PROTO(( yyconst char *yy_str )); +YY_BUFFER_STATE yy_scan_bytes YY_PROTO(( yyconst char *bytes, int len )); + +static void *yy_flex_alloc YY_PROTO(( yy_size_t )); +static void *yy_flex_realloc YY_PROTO(( void *, yy_size_t )); +static void yy_flex_free YY_PROTO(( void * )); + +#define yy_new_buffer yy_create_buffer + +#define yy_set_interactive(is_interactive) \ + { \ + if ( ! yy_current_buffer ) \ + yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \ + yy_current_buffer->yy_is_interactive = is_interactive; \ + } + +#define yy_set_bol(at_bol) \ + { \ + if ( ! yy_current_buffer ) \ + yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); \ + yy_current_buffer->yy_at_bol = at_bol; \ + } + +#define YY_AT_BOL() (yy_current_buffer->yy_at_bol) + +typedef unsigned char YY_CHAR; +FILE *yyin = (FILE *) 0, *yyout = (FILE *) 0; +typedef int yy_state_type; +extern char *yytext; +#define yytext_ptr yytext + +static yy_state_type yy_get_previous_state YY_PROTO(( void )); +static yy_state_type yy_try_NUL_trans YY_PROTO(( yy_state_type current_state )); +static int yy_get_next_buffer YY_PROTO(( void )); +static void yy_fatal_error YY_PROTO(( yyconst char msg[] )); + +/* Done after the current pattern has been matched and before the + * corresponding action - sets up yytext. + */ +#define YY_DO_BEFORE_ACTION \ + yytext_ptr = yy_bp; \ + yyleng = (int) (yy_cp - yy_bp); \ + yy_hold_char = *yy_cp; \ + *yy_cp = '\0'; \ + yy_c_buf_p = yy_cp; + +#define YY_NUM_RULES 101 +#define YY_END_OF_BUFFER 102 +static yyconst short int yy_accept[581] = + { 0, + 0, 0, 102, 100, 2, 1, 99, 100, 100, 100, + 100, 91, 91, 91, 100, 100, 100, 5, 100, 1, + 100, 91, 91, 100, 91, 4, 3, 91, 93, 100, + 92, 91, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 91, 100, 3, 3, 93, + 100, 91, 92, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 67, 100, 100, + 100, 95, 100, 100, 96, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 19, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 33, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 82, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + + 100, 100, 100, 100, 100, 100, 100, 100, 25, 100, + 100, 100, 100, 23, 100, 100, 100, 100, 100, 32, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 53, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 68, + 100, 100, 100, 100, 100, 100, 100, 100, 79, 100, + 100, 100, 100, 100, 100, 94, 100, 97, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 20, 100, 100, 100, 100, 24, 100, 29, 100, 100, + 100, 100, 100, 100, 38, 39, 100, 100, 100, 44, + + 100, 100, 100, 100, 100, 100, 100, 54, 100, 56, + 57, 58, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 75, 100, 78, 100, 100, 100, + 100, 100, 100, 94, 98, 100, 100, 8, 100, 100, + 100, 13, 100, 100, 100, 100, 100, 100, 100, 22, + 27, 100, 100, 31, 100, 100, 34, 35, 100, 100, + 43, 100, 100, 100, 100, 49, 100, 100, 100, 100, + 100, 100, 61, 100, 100, 100, 66, 100, 100, 100, + 100, 100, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 12, 14, 100, 100, 100, 100, + + 100, 100, 100, 100, 100, 100, 100, 100, 100, 45, + 100, 100, 100, 100, 100, 100, 55, 59, 60, 100, + 100, 64, 100, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 100, 100, 85, 100, 100, 100, 100, 100, + 100, 100, 100, 15, 16, 100, 100, 100, 21, 100, + 100, 36, 100, 100, 41, 42, 100, 100, 100, 100, + 100, 52, 100, 63, 100, 69, 70, 71, 100, 100, + 100, 100, 80, 81, 83, 84, 100, 100, 100, 100, + 100, 100, 100, 11, 100, 100, 26, 100, 100, 37, + 40, 100, 100, 100, 100, 100, 62, 100, 72, 100, + + 100, 100, 100, 100, 100, 100, 89, 100, 100, 100, + 9, 100, 17, 100, 100, 100, 100, 100, 100, 100, + 100, 100, 73, 74, 100, 100, 100, 100, 88, 100, + 100, 100, 100, 100, 100, 30, 46, 100, 48, 50, + 51, 100, 100, 100, 86, 87, 100, 6, 7, 100, + 100, 100, 100, 100, 76, 100, 90, 100, 100, 100, + 47, 100, 100, 100, 100, 100, 100, 77, 100, 100, + 100, 100, 10, 100, 100, 65, 18, 100, 28, 0 + } ; + +static yyconst int yy_ec[256] = + { 0, + 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, + 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 2, 1, 4, 5, 6, 1, 1, 1, 1, + 1, 7, 8, 1, 9, 10, 11, 12, 13, 14, + 15, 16, 14, 14, 14, 14, 14, 1, 1, 17, + 1, 18, 1, 1, 20, 21, 22, 23, 24, 25, + 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, + 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, + 1, 1, 1, 1, 19, 1, 20, 21, 22, 23, + + 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, + 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, + 44, 45, 46, 1, 46, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1 + } ; + +static yyconst int yy_meta[47] = + { 0, + 1, 2, 3, 2, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 2 + } ; + +static yyconst short int yy_base[586] = + { 0, + 0, 45, 702, 0, 703, 0, 703, 8, 82, 22, + 18, 101, 9, 20, 125, 668, 680, 703, 0, 0, + 52, 29, 59, 666, 69, 0, 40, 114, 14, 161, + 166, 187, 665, 79, 108, 192, 12, 660, 668, 662, + 660, 660, 11, 86, 36, 50, 658, 75, 191, 185, + 99, 221, 666, 665, 656, 241, 663, 75, 0, 19, + 235, 246, 0, 659, 658, 640, 664, 100, 650, 662, + 647, 162, 662, 642, 640, 639, 642, 649, 637, 632, + 628, 638, 639, 630, 634, 632, 186, 638, 631, 631, + 629, 623, 638, 636, 622, 621, 628, 633, 616, 106, + + 629, 632, 613, 631, 630, 613, 628, 619, 79, 603, + 621, 199, 605, 613, 612, 623, 610, 0, 609, 601, + 605, 0, 624, 607, 0, 601, 601, 604, 609, 599, + 595, 605, 590, 588, 594, 163, 587, 0, 584, 604, + 582, 583, 598, 594, 599, 571, 595, 590, 594, 572, + 593, 0, 579, 570, 575, 568, 582, 570, 51, 580, + 578, 570, 580, 576, 575, 559, 564, 552, 577, 574, + 223, 560, 561, 551, 567, 550, 557, 569, 560, 93, + 552, 551, 558, 151, 564, 548, 547, 0, 546, 545, + 538, 570, 532, 541, 548, 537, 547, 546, 548, 531, + + 536, 559, 541, 536, 539, 528, 538, 542, 0, 539, + 526, 537, 531, 0, 537, 522, 535, 525, 516, 0, + 510, 529, 509, 509, 528, 527, 507, 515, 511, 523, + 520, 501, 516, 500, 516, 496, 508, 0, 515, 493, + 513, 512, 511, 500, 186, 503, 498, 503, 500, 0, + 499, 494, 481, 494, 481, 500, 484, 498, 0, 481, + 480, 479, 478, 487, 490, 257, 484, 0, 471, 470, + 488, 471, 472, 479, 484, 478, 477, 466, 465, 469, + 0, 463, 475, 476, 475, 0, 464, 0, 467, 472, + 466, 455, 469, 468, 0, 0, 457, 441, 465, 0, + + 451, 199, 442, 462, 446, 447, 443, 0, 452, 0, + 0, 0, 443, 437, 455, 439, 438, 443, 451, 435, + 429, 429, 426, 136, 0, 438, 0, 424, 423, 422, + 421, 416, 425, 0, 0, 433, 434, 0, 435, 434, + 435, 0, 434, 427, 411, 425, 415, 425, 415, 0, + 0, 423, 424, 0, 419, 420, 0, 0, 421, 169, + 0, 422, 399, 398, 398, 0, 410, 407, 401, 415, + 414, 413, 0, 408, 403, 216, 0, 389, 388, 402, + 398, 390, 403, 391, 383, 382, 381, 380, 256, 389, + 385, 375, 377, 382, 0, 0, 394, 393, 377, 389, + + 384, 389, 365, 382, 386, 379, 371, 383, 382, 0, + 362, 361, 353, 372, 369, 376, 0, 0, 0, 369, + 374, 0, 357, 372, 371, 370, 349, 349, 346, 360, + 365, 364, 363, 362, 0, 346, 344, 353, 344, 341, + 337, 350, 354, 0, 0, 332, 331, 351, 0, 344, + 343, 0, 348, 347, 0, 0, 323, 338, 327, 328, + 333, 0, 341, 0, 325, 0, 0, 0, 339, 324, + 331, 250, 0, 0, 0, 0, 326, 319, 327, 223, + 331, 309, 265, 0, 331, 324, 0, 310, 309, 0, + 0, 321, 324, 319, 303, 302, 0, 317, 0, 321, + + 320, 317, 297, 303, 303, 315, 0, 294, 308, 306, + 0, 305, 0, 290, 288, 308, 307, 302, 305, 304, + 303, 292, 0, 0, 286, 281, 299, 298, 0, 309, + 296, 295, 279, 267, 286, 0, 0, 285, 0, 0, + 0, 269, 289, 278, 0, 0, 287, 0, 0, 265, + 265, 249, 272, 261, 0, 251, 0, 261, 245, 229, + 0, 229, 234, 207, 202, 183, 174, 0, 154, 111, + 107, 118, 0, 71, 43, 0, 0, 33, 0, 703, + 293, 0, 296, 298, 300 + } ; + +static yyconst short int yy_def[586] = + { 0, + 581, 581, 580, 582, 580, 583, 580, 582, 582, 582, + 582, 582, 12, 12, 582, 582, 582, 580, 582, 583, + 582, 12, 12, 582, 582, 582, 584, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 584, 585, 582, + 582, 582, 31, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 266, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 582, + 582, 582, 582, 582, 582, 582, 582, 582, 582, 0, + 580, 580, 580, 580, 580 + } ; + +static yyconst short int yy_nxt[750] = + { 0, + 19, 5, 6, 7, 580, 580, 580, 8, 9, 10, + 11, 12, 13, 14, 14, 14, 15, 21, 32, 22, + 22, 22, 22, 22, 26, 60, 60, 16, 27, 19, + 60, 60, 17, 25, 25, 25, 25, 25, 90, 83, + 19, 59, 84, 59, 91, 18, 5, 6, 7, 19, + 579, 19, 8, 9, 10, 11, 12, 13, 14, 14, + 14, 15, 19, 25, 25, 25, 25, 25, 56, 95, + 97, 19, 16, 578, 227, 96, 59, 17, 59, 19, + 25, 25, 25, 25, 25, 59, 98, 228, 577, 99, + 18, 21, 30, 22, 23, 22, 22, 22, 101, 177, + + 102, 19, 66, 67, 178, 92, 68, 114, 103, 24, + 28, 179, 22, 22, 22, 22, 22, 115, 69, 93, + 59, 29, 94, 252, 30, 25, 25, 25, 25, 25, + 130, 253, 131, 167, 70, 576, 168, 30, 71, 116, + 575, 72, 574, 31, 33, 34, 35, 36, 73, 37, + 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, + 382, 48, 49, 50, 51, 52, 383, 53, 61, 61, + 257, 573, 62, 62, 62, 62, 62, 63, 63, 63, + 63, 63, 258, 408, 409, 63, 63, 63, 63, 63, + 63, 64, 135, 136, 205, 137, 104, 206, 25, 25, + + 25, 25, 25, 152, 109, 314, 572, 153, 110, 315, + 30, 74, 105, 75, 106, 111, 571, 107, 182, 76, + 363, 112, 183, 154, 77, 570, 184, 113, 78, 117, + 79, 80, 108, 422, 81, 82, 364, 423, 118, 119, + 507, 508, 240, 569, 120, 124, 62, 62, 62, 62, + 62, 568, 25, 25, 25, 25, 25, 62, 62, 62, + 62, 62, 567, 566, 30, 241, 242, 243, 334, 334, + 334, 334, 334, 435, 502, 436, 334, 334, 334, 334, + 334, 334, 511, 565, 564, 563, 512, 503, 562, 561, + 437, 560, 438, 4, 4, 4, 20, 20, 58, 58, + + 59, 59, 559, 558, 557, 556, 555, 554, 553, 552, + 551, 550, 549, 548, 547, 546, 545, 544, 543, 542, + 541, 540, 539, 538, 537, 536, 535, 534, 533, 532, + 531, 530, 529, 528, 527, 526, 525, 524, 523, 522, + 521, 520, 519, 518, 517, 516, 515, 514, 513, 510, + 509, 506, 505, 504, 501, 500, 499, 498, 497, 496, + 495, 494, 493, 492, 491, 490, 489, 488, 487, 486, + 485, 484, 483, 482, 481, 480, 479, 478, 477, 476, + 475, 474, 473, 472, 471, 470, 469, 468, 467, 466, + 465, 464, 463, 462, 461, 460, 459, 458, 457, 456, + + 455, 454, 453, 452, 451, 450, 449, 448, 447, 446, + 445, 444, 443, 442, 441, 440, 439, 434, 433, 432, + 431, 430, 429, 428, 427, 426, 425, 424, 421, 420, + 419, 418, 417, 416, 415, 414, 413, 412, 411, 410, + 407, 406, 405, 404, 403, 402, 401, 400, 399, 398, + 397, 396, 395, 394, 393, 392, 391, 390, 389, 388, + 387, 386, 385, 384, 381, 380, 379, 378, 377, 376, + 375, 374, 373, 372, 371, 370, 369, 368, 367, 366, + 365, 362, 361, 360, 359, 358, 357, 356, 355, 354, + 353, 352, 351, 350, 349, 348, 347, 346, 345, 344, + + 343, 342, 341, 340, 339, 338, 337, 336, 335, 333, + 332, 331, 330, 329, 328, 327, 326, 325, 324, 323, + 322, 321, 320, 319, 318, 317, 316, 313, 312, 311, + 310, 309, 308, 307, 306, 305, 304, 303, 302, 301, + 300, 299, 298, 297, 296, 295, 294, 293, 292, 291, + 290, 289, 288, 287, 286, 285, 284, 283, 282, 281, + 280, 279, 278, 277, 276, 275, 274, 273, 272, 271, + 270, 269, 268, 267, 266, 265, 264, 263, 262, 261, + 260, 259, 256, 255, 254, 251, 250, 249, 248, 247, + 246, 245, 244, 239, 238, 237, 236, 235, 234, 233, + + 232, 231, 230, 229, 226, 225, 224, 223, 222, 221, + 220, 219, 218, 217, 216, 215, 214, 213, 212, 211, + 210, 209, 208, 207, 204, 203, 202, 201, 200, 199, + 198, 197, 196, 195, 194, 193, 192, 191, 190, 189, + 188, 187, 186, 185, 181, 180, 176, 175, 174, 173, + 172, 171, 170, 169, 166, 165, 164, 163, 162, 161, + 160, 159, 158, 157, 156, 155, 151, 150, 149, 148, + 147, 146, 145, 144, 143, 142, 141, 140, 139, 138, + 134, 133, 132, 129, 128, 127, 126, 125, 123, 122, + 121, 100, 89, 88, 87, 86, 85, 65, 57, 55, + + 54, 580, 3, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580 + } ; + +static yyconst short int yy_chk[750] = + { 0, + 582, 1, 1, 1, 0, 0, 0, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 8, 13, 8, + 8, 8, 8, 8, 11, 29, 29, 1, 11, 13, + 60, 60, 1, 10, 10, 10, 10, 10, 43, 37, + 14, 27, 37, 27, 43, 1, 2, 2, 2, 22, + 578, 13, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 14, 21, 21, 21, 21, 21, 23, 45, + 46, 22, 2, 575, 159, 45, 58, 2, 58, 23, + 25, 25, 25, 25, 25, 27, 46, 159, 574, 46, + 2, 9, 25, 9, 9, 9, 9, 9, 48, 109, + + 48, 23, 34, 34, 109, 44, 34, 51, 48, 9, + 12, 109, 12, 12, 12, 12, 12, 51, 34, 44, + 58, 12, 44, 180, 12, 28, 28, 28, 28, 28, + 68, 180, 68, 100, 35, 572, 100, 28, 35, 51, + 571, 35, 570, 12, 15, 15, 15, 15, 35, 15, + 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, + 324, 15, 15, 15, 15, 15, 324, 15, 30, 30, + 184, 569, 30, 30, 30, 30, 30, 31, 31, 31, + 31, 31, 184, 360, 360, 31, 31, 31, 31, 31, + 31, 32, 72, 72, 136, 72, 49, 136, 32, 32, + + 32, 32, 32, 87, 50, 245, 567, 87, 50, 245, + 32, 36, 49, 36, 49, 50, 566, 49, 112, 36, + 302, 50, 112, 87, 36, 565, 112, 50, 36, 52, + 36, 36, 49, 376, 36, 36, 302, 376, 52, 52, + 480, 480, 171, 564, 52, 56, 61, 61, 61, 61, + 61, 563, 56, 56, 56, 56, 56, 62, 62, 62, + 62, 62, 562, 560, 56, 171, 171, 171, 266, 266, + 266, 266, 266, 389, 472, 389, 266, 266, 266, 266, + 266, 266, 483, 559, 558, 556, 483, 472, 554, 553, + 389, 552, 389, 581, 581, 581, 583, 583, 584, 584, + + 585, 585, 551, 550, 547, 544, 543, 542, 538, 535, + 534, 533, 532, 531, 530, 528, 527, 526, 525, 522, + 521, 520, 519, 518, 517, 516, 515, 514, 512, 510, + 509, 508, 506, 505, 504, 503, 502, 501, 500, 498, + 496, 495, 494, 493, 492, 489, 488, 486, 485, 482, + 481, 479, 478, 477, 471, 470, 469, 465, 463, 461, + 460, 459, 458, 457, 454, 453, 451, 450, 448, 447, + 446, 443, 442, 441, 440, 439, 438, 437, 436, 434, + 433, 432, 431, 430, 429, 428, 427, 426, 425, 424, + 423, 421, 420, 416, 415, 414, 413, 412, 411, 409, + + 408, 407, 406, 405, 404, 403, 402, 401, 400, 399, + 398, 397, 394, 393, 392, 391, 390, 388, 387, 386, + 385, 384, 383, 382, 381, 380, 379, 378, 375, 374, + 372, 371, 370, 369, 368, 367, 365, 364, 363, 362, + 359, 356, 355, 353, 352, 349, 348, 347, 346, 345, + 344, 343, 341, 340, 339, 337, 336, 333, 332, 331, + 330, 329, 328, 326, 323, 322, 321, 320, 319, 318, + 317, 316, 315, 314, 313, 309, 307, 306, 305, 304, + 303, 301, 299, 298, 297, 294, 293, 292, 291, 290, + 289, 287, 285, 284, 283, 282, 280, 279, 278, 277, + + 276, 275, 274, 273, 272, 271, 270, 269, 267, 265, + 264, 263, 262, 261, 260, 258, 257, 256, 255, 254, + 253, 252, 251, 249, 248, 247, 246, 244, 243, 242, + 241, 240, 239, 237, 236, 235, 234, 233, 232, 231, + 230, 229, 228, 227, 226, 225, 224, 223, 222, 221, + 219, 218, 217, 216, 215, 213, 212, 211, 210, 208, + 207, 206, 205, 204, 203, 202, 201, 200, 199, 198, + 197, 196, 195, 194, 193, 192, 191, 190, 189, 187, + 186, 185, 183, 182, 181, 179, 178, 177, 176, 175, + 174, 173, 172, 170, 169, 168, 167, 166, 165, 164, + + 163, 162, 161, 160, 158, 157, 156, 155, 154, 153, + 151, 150, 149, 148, 147, 146, 145, 144, 143, 142, + 141, 140, 139, 137, 135, 134, 133, 132, 131, 130, + 129, 128, 127, 126, 124, 123, 121, 120, 119, 117, + 116, 115, 114, 113, 111, 110, 108, 107, 106, 105, + 104, 103, 102, 101, 99, 98, 97, 96, 95, 94, + 93, 92, 91, 90, 89, 88, 86, 85, 84, 83, + 82, 81, 80, 79, 78, 77, 76, 75, 74, 73, + 71, 70, 69, 67, 66, 65, 64, 57, 55, 54, + 53, 47, 42, 41, 40, 39, 38, 33, 24, 17, + + 16, 3, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580, 580, + 580, 580, 580, 580, 580, 580, 580, 580, 580 + } ; + +static yy_state_type yy_last_accepting_state; +static char *yy_last_accepting_cpos; + +/* The intent behind this definition is that it'll catch + * any uses of REJECT which flex missed. + */ +#define REJECT reject_used_but_not_detected +#define yymore() yymore_used_but_not_detected +#define YY_MORE_ADJ 0 +#define YY_RESTORE_YY_MORE_OFFSET +char *yytext; +#line 1 "lexer.lxx" +#define INITIAL 0 +/* +// Filename: lexer.l +// Created by: drose (16Jan99) +// +//////////////////////////////////////////////////////////////////// +*/ +#line 9 "lexer.lxx" +#include "pandabase.h" +#include "lexerDefs.h" +#include "parserDefs.h" +#include "config_egg.h" +#include "parser.h" +#include "indent.h" +#include "pnotify.h" +#include "pmutex.h" +#include "thread.h" + +#include + +extern "C" int eggyywrap(void); // declared below. + +static int yyinput(void); // declared by flex. + + +//////////////////////////////////////////////////////////////////// +// Static variables +//////////////////////////////////////////////////////////////////// + +// This mutex protects all of these global variables. +Mutex egg_lock; + +// We'll increment line_number and col_number as we parse the file, so +// that we can report the position of an error. +static int line_number = 0; +static int col_number = 0; + +// current_line holds as much of the current line as will fit. Its +// only purpose is for printing it out to report an error to the user. +static const int max_error_width = 1024; +static char current_line[max_error_width + 1]; + +static int error_count = 0; +static int warning_count = 0; + +// This is the pointer to the current input stream. +static istream *inp = NULL; + +// This is the name of the egg file we're parsing. We keep it so we +// can print it out for error messages. +static string egg_filename; + +// This is the initial token state returned by the lexer. It allows +// the yacc grammar to start from initial points. +static int initial_token; + +//////////////////////////////////////////////////////////////////// +// Defining the interface to the lexer. +//////////////////////////////////////////////////////////////////// + +void +egg_init_lexer(istream &in, const string &filename) { + inp = ∈ + egg_filename = filename; + line_number = 0; + col_number = 0; + error_count = 0; + warning_count = 0; + initial_token = START_EGG; +} + +void +egg_start_group_body() { + /* Set the initial state to begin within a group_body context, + instead of at the beginning of the egg file. */ + initial_token = START_GROUP_BODY; +} + +void +egg_start_texture_body() { + initial_token = START_TEXTURE_BODY; +} + +void +egg_start_primitive_body() { + initial_token = START_PRIMITIVE_BODY; +} + +int +egg_error_count() { + return error_count; +} + +int +egg_warning_count() { + return warning_count; +} + + +//////////////////////////////////////////////////////////////////// +// Internal support functions. +//////////////////////////////////////////////////////////////////// + +int +eggyywrap(void) { + return 1; +} + +void +eggyyerror(const string &msg) { + if (egg_cat.is_error()) { + ostream &out = egg_cat.error(false); + + out << "\nError"; + if (!egg_filename.empty()) { + out << " in " << egg_filename; + } + out + << " at line " << line_number << ", column " << col_number << ":\n" + << setiosflags(Notify::get_literal_flag()) + << current_line << "\n"; + indent(out, col_number-1) + << "^\n" << msg << "\n\n" + << resetiosflags(Notify::get_literal_flag()) << flush; + } + error_count++; +} + +void +eggyyerror(ostringstream &strm) { + string s = strm.str(); + eggyyerror(s); +} + +void +eggyywarning(const string &msg) { + if (egg_cat.is_warning()) { + ostream &out = egg_cat.warning(false); + + out << "\nWarning"; + if (!egg_filename.empty()) { + out << " in " << egg_filename; + } + out + << " at line " << line_number << ", column " << col_number << ":\n" + << setiosflags(Notify::get_literal_flag()) + << current_line << "\n"; + indent(out, col_number-1) + << "^\n" << msg << "\n\n" + << resetiosflags(Notify::get_literal_flag()) << flush; + } + warning_count++; +} + +void +eggyywarning(ostringstream &strm) { + string s = strm.str(); + eggyywarning(s); +} + +// Now define a function to take input from an istream instead of a +// stdio FILE pointer. This is flex-specific. +static void +input_chars(char *buffer, int &result, int max_size) { + nassertv(inp != NULL); + if (*inp) { + inp->read(buffer, max_size); + result = inp->gcount(); + + if (line_number == 0) { + // This is a special case. If we are reading the very first bit + // from the stream, copy it into the current_line array. This + // is because the \n.* rule below, which fills current_line + // normally, doesn't catch the first line. + int length = min(max_error_width, result); + strncpy(current_line, buffer, length); + current_line[length] = '\0'; + line_number++; + col_number = 0; + + // Truncate it at the newline. + char *end = strchr(current_line, '\n'); + if (end != NULL) { + *end = '\0'; + } + } + + } else { + // End of file or I/O error. + result = 0; + } + Thread::consider_yield(); +} +#undef YY_INPUT +#define YY_INPUT(buffer, result, max_size) input_chars(buffer, result, max_size) + +// read_char reads and returns a single character, incrementing the +// supplied line and column numbers as appropriate. A convenience +// function for the scanning functions below. +static int +read_char(int &line, int &col) { + int c = yyinput(); + if (c == '\n') { + line++; + col = 0; + } else { + col++; + } + return c; +} + +// scan_quoted_string reads a string delimited by quotation marks and +// returns it. +static string +scan_quoted_string() { + string result; + + // We don't touch the current line number and column number during + // scanning, so that if we detect an error while scanning the string + // (e.g. an unterminated string), we'll report the error as + // occurring at the start of the string, not at the end--somewhat + // more convenient for the user. + + // Instead of adjusting the global line_number and col_number + // variables, we'll operate on our own local variables for the + // interim. + int line = line_number; + int col = col_number; + + int c; + c = read_char(line, col); + while (c != '"' && c != EOF) { + result += c; + c = read_char(line, col); + } + + if (c == EOF) { + eggyyerror("This quotation mark is unterminated."); + } + + line_number = line; + col_number = col; + + return result; +} + +// eat_c_comment scans past all characters up until the first */ +// encountered. +static void +eat_c_comment() { + // As above, we'll operate on our own local copies of line_number + // and col_number within this function. + + int line = line_number; + int col = col_number; + + int c, last_c; + + last_c = '\0'; + c = read_char(line, col); + while (c != EOF && !(last_c == '*' && c == '/')) { + if (last_c == '/' && c == '*') { + ostringstream errmsg; + errmsg << "This comment contains a nested /* symbol at line " + << line << ", column " << col-1 << "--possibly unclosed?" + << ends; + eggyywarning(errmsg); + } + last_c = c; + c = read_char(line, col); + } + + if (c == EOF) { + eggyyerror("This comment marker is unclosed."); + } + + line_number = line; + col_number = col; +} + + +// accept() is called below as each piece is pulled off and +// accepted by the lexer; it increments the current column number. +INLINE void accept() { + col_number += yyleng; +} + +#line 1022 "lex.yy.c" + +/* Macros after this point can all be overridden by user definitions in + * section 1. + */ + +#ifndef YY_SKIP_YYWRAP +#ifdef __cplusplus +extern "C" int yywrap YY_PROTO(( void )); +#else +extern int yywrap YY_PROTO(( void )); +#endif +#endif + +#ifndef YY_NO_UNPUT +static void yyunput YY_PROTO(( int c, char *buf_ptr )); +#endif + +#ifndef yytext_ptr +static void yy_flex_strncpy YY_PROTO(( char *, yyconst char *, int )); +#endif + +#ifdef YY_NEED_STRLEN +static int yy_flex_strlen YY_PROTO(( yyconst char * )); +#endif + +#ifndef YY_NO_INPUT +#ifdef __cplusplus +static int yyinput YY_PROTO(( void )); +#else +static int input YY_PROTO(( void )); +#endif +#endif + +#if YY_STACK_USED +static int yy_start_stack_ptr = 0; +static int yy_start_stack_depth = 0; +static int *yy_start_stack = 0; +#ifndef YY_NO_PUSH_STATE +static void yy_push_state YY_PROTO(( int new_state )); +#endif +#ifndef YY_NO_POP_STATE +static void yy_pop_state YY_PROTO(( void )); +#endif +#ifndef YY_NO_TOP_STATE +static int yy_top_state YY_PROTO(( void )); +#endif + +#else +#define YY_NO_PUSH_STATE 1 +#define YY_NO_POP_STATE 1 +#define YY_NO_TOP_STATE 1 +#endif + +#ifdef YY_MALLOC_DECL +YY_MALLOC_DECL +#else +#if __STDC__ +#ifndef __cplusplus +#include +#endif +#else +/* Just try to get by without declaring the routines. This will fail + * miserably on non-ANSI systems for which sizeof(size_t) != sizeof(int) + * or sizeof(void*) != sizeof(int). + */ +#endif +#endif + +/* Amount of stuff to slurp up with each read. */ +#ifndef YY_READ_BUF_SIZE +#define YY_READ_BUF_SIZE 8192 +#endif + +/* Copy whatever the last rule matched to the standard output. */ + +#ifndef ECHO +/* This used to be an fputs(), but since the string might contain NUL's, + * we now use fwrite(). + */ +#define ECHO (void) fwrite( yytext, yyleng, 1, yyout ) +#endif + +/* Gets input and stuffs it into "buf". number of characters read, or YY_NULL, + * is returned in "result". + */ +#ifndef YY_INPUT +#define YY_INPUT(buf,result,max_size) \ + if ( yy_current_buffer->yy_is_interactive ) \ + { \ + int c = '*', n; \ + for ( n = 0; n < max_size && \ + (c = getc( yyin )) != EOF && c != '\n'; ++n ) \ + buf[n] = (char) c; \ + if ( c == '\n' ) \ + buf[n++] = (char) c; \ + if ( c == EOF && ferror( yyin ) ) \ + YY_FATAL_ERROR( "input in flex scanner failed" ); \ + result = n; \ + } \ + else if ( ((result = fread( buf, 1, max_size, yyin )) == 0) \ + && ferror( yyin ) ) \ + YY_FATAL_ERROR( "input in flex scanner failed" ); +#endif + +/* No semi-colon after return; correct usage is to write "yyterminate();" - + * we don't want an extra ';' after the "return" because that will cause + * some compilers to complain about unreachable statements. + */ +#ifndef yyterminate +#define yyterminate() return YY_NULL +#endif + +/* Number of entries by which start-condition stack grows. */ +#ifndef YY_START_STACK_INCR +#define YY_START_STACK_INCR 25 +#endif + +/* Report a fatal error. */ +#ifndef YY_FATAL_ERROR +#define YY_FATAL_ERROR(msg) yy_fatal_error( msg ) +#endif + +/* Default declaration of generated scanner - a define so the user can + * easily add parameters. + */ +#ifndef YY_DECL +#define YY_DECL int yylex YY_PROTO(( void )) +#endif + +/* Code executed at the beginning of each rule, after yytext and yyleng + * have been set up. + */ +#ifndef YY_USER_ACTION +#define YY_USER_ACTION +#endif + +/* Code executed at the end of each rule. */ +#ifndef YY_BREAK +#define YY_BREAK break; +#endif + +#define YY_RULE_SETUP \ + YY_USER_ACTION + +YY_DECL + { + register yy_state_type yy_current_state; + register char *yy_cp, *yy_bp; + register int yy_act; + +#line 294 "lexer.lxx" + + + + if (initial_token != 0) { + int t = initial_token; + initial_token = 0; + return t; + } + + +#line 1184 "lex.yy.c" + + if ( yy_init ) + { + yy_init = 0; + +#ifdef YY_USER_INIT + YY_USER_INIT; +#endif + + if ( ! yy_start ) + yy_start = 1; /* first start state */ + + if ( ! yyin ) + yyin = stdin; + + if ( ! yyout ) + yyout = stdout; + + if ( ! yy_current_buffer ) + yy_current_buffer = + yy_create_buffer( yyin, YY_BUF_SIZE ); + + yy_load_buffer_state(); + } + + while ( 1 ) /* loops until end-of-file is reached */ + { + yy_cp = yy_c_buf_p; + + /* Support of yytext. */ + *yy_cp = yy_hold_char; + + /* yy_bp points to the position in yy_ch_buf of the start of + * the current run. + */ + yy_bp = yy_cp; + + yy_current_state = yy_start; +yy_match: + do + { + register YY_CHAR yy_c = yy_ec[YY_SC_TO_UI(*yy_cp)]; + if ( yy_accept[yy_current_state] ) + { + yy_last_accepting_state = yy_current_state; + yy_last_accepting_cpos = yy_cp; + } + while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) + { + yy_current_state = (int) yy_def[yy_current_state]; + if ( yy_current_state >= 581 ) + yy_c = yy_meta[(unsigned int) yy_c]; + } + yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; + ++yy_cp; + } + while ( yy_base[yy_current_state] != 703 ); + +yy_find_action: + yy_act = yy_accept[yy_current_state]; + if ( yy_act == 0 ) + { /* have to back up */ + yy_cp = yy_last_accepting_cpos; + yy_current_state = yy_last_accepting_state; + yy_act = yy_accept[yy_current_state]; + } + + YY_DO_BEFORE_ACTION; + + +do_action: /* This label is used only to access EOF actions. */ + + + switch ( yy_act ) + { /* beginning of action switch */ + case 0: /* must back up */ + /* undo the effects of YY_DO_BEFORE_ACTION */ + *yy_cp = yy_hold_char; + yy_cp = yy_last_accepting_cpos; + yy_current_state = yy_last_accepting_state; + goto yy_find_action; + +case 1: +YY_RULE_SETUP +#line 304 "lexer.lxx" +{ + // New line. Save a copy of the line so we can print it out for the + // benefit of the user in case we get an error. + + strncpy(current_line, yytext+1, max_error_width); + current_line[max_error_width] = '\0'; + line_number++; + col_number=0; + + // Return the whole line to the lexer, except the newline character, + // which we eat. + yyless(1); +} + YY_BREAK +case 2: +YY_RULE_SETUP +#line 318 "lexer.lxx" +{ + // Eat whitespace. + accept(); +} + YY_BREAK +case 3: +YY_RULE_SETUP +#line 323 "lexer.lxx" +{ + // Eat C++-style comments. + accept(); +} + YY_BREAK +case 4: +YY_RULE_SETUP +#line 328 "lexer.lxx" +{ + // Eat C-style comments. + accept(); + eat_c_comment(); +} + YY_BREAK +case 5: +YY_RULE_SETUP +#line 334 "lexer.lxx" +{ + // Send curly braces as themselves. + accept(); + return eggyytext[0]; +} + YY_BREAK +case 6: +YY_RULE_SETUP +#line 342 "lexer.lxx" +{ + accept(); + return ANIMPRELOAD; +} + YY_BREAK +case 7: +YY_RULE_SETUP +#line 346 "lexer.lxx" +{ + accept(); + return BEZIERCURVE; +} + YY_BREAK +case 8: +YY_RULE_SETUP +#line 350 "lexer.lxx" +{ + accept(); + return BFACE; +} + YY_BREAK +case 9: +YY_RULE_SETUP +#line 354 "lexer.lxx" +{ + accept(); + return BILLBOARD; +} + YY_BREAK +case 10: +YY_RULE_SETUP +#line 358 "lexer.lxx" +{ + accept(); + return BILLBOARDCENTER; +} + YY_BREAK +case 11: +YY_RULE_SETUP +#line 362 "lexer.lxx" +{ + accept(); + return BINORMAL; +} + YY_BREAK +case 12: +YY_RULE_SETUP +#line 366 "lexer.lxx" +{ + accept(); + return BUNDLE; +} + YY_BREAK +case 13: +YY_RULE_SETUP +#line 370 "lexer.lxx" +{ + accept(); + return SCALAR; +} + YY_BREAK +case 14: +YY_RULE_SETUP +#line 374 "lexer.lxx" +{ + accept(); + return CLOSED; +} + YY_BREAK +case 15: +YY_RULE_SETUP +#line 378 "lexer.lxx" +{ + accept(); + return COLLIDE; +} + YY_BREAK +case 16: +YY_RULE_SETUP +#line 382 "lexer.lxx" +{ + accept(); + return COMMENT; +} + YY_BREAK +case 17: +YY_RULE_SETUP +#line 386 "lexer.lxx" +{ + accept(); + return COMPONENT; +} + YY_BREAK +case 18: +YY_RULE_SETUP +#line 390 "lexer.lxx" +{ + accept(); + return COORDSYSTEM; +} + YY_BREAK +case 19: +YY_RULE_SETUP +#line 394 "lexer.lxx" +{ + accept(); + return CV; +} + YY_BREAK +case 20: +YY_RULE_SETUP +#line 398 "lexer.lxx" +{ + accept(); + return DART; +} + YY_BREAK +case 21: +YY_RULE_SETUP +#line 402 "lexer.lxx" +{ + accept(); + return DNORMAL; +} + YY_BREAK +case 22: +YY_RULE_SETUP +#line 406 "lexer.lxx" +{ + accept(); + return DRGBA; +} + YY_BREAK +case 23: +YY_RULE_SETUP +#line 410 "lexer.lxx" +{ + accept(); + return DUV; +} + YY_BREAK +case 24: +YY_RULE_SETUP +#line 414 "lexer.lxx" +{ + accept(); + return DXYZ; +} + YY_BREAK +case 25: +YY_RULE_SETUP +#line 418 "lexer.lxx" +{ + accept(); + return DCS; +} + YY_BREAK +case 26: +YY_RULE_SETUP +#line 422 "lexer.lxx" +{ + accept(); + return DISTANCE; +} + YY_BREAK +case 27: +YY_RULE_SETUP +#line 426 "lexer.lxx" +{ + accept(); + return DTREF; +} + YY_BREAK +case 28: +YY_RULE_SETUP +#line 430 "lexer.lxx" +{ + accept(); + return DYNAMICVERTEXPOOL; +} + YY_BREAK +case 29: +YY_RULE_SETUP +#line 434 "lexer.lxx" +{ + accept(); + return EXTERNAL_FILE; +} + YY_BREAK +case 30: +YY_RULE_SETUP +#line 438 "lexer.lxx" +{ + accept(); + return FLIGHT; +} + YY_BREAK +case 31: +YY_RULE_SETUP +#line 442 "lexer.lxx" +{ + accept(); + return GROUP; +} + YY_BREAK +case 32: +YY_RULE_SETUP +#line 446 "lexer.lxx" +{ + accept(); + return HIP; +} + YY_BREAK +case 33: +YY_RULE_SETUP +#line 450 "lexer.lxx" +{ + accept(); + return INTANGENT; +} + YY_BREAK +case 34: +YY_RULE_SETUP +#line 454 "lexer.lxx" +{ + accept(); + return JOINT; +} + YY_BREAK +case 35: +YY_RULE_SETUP +#line 458 "lexer.lxx" +{ + accept(); + return KNOTS; +} + YY_BREAK +case 36: +YY_RULE_SETUP +#line 462 "lexer.lxx" +{ + accept(); + return INCLUDE; +} + YY_BREAK +case 37: +YY_RULE_SETUP +#line 466 "lexer.lxx" +{ + accept(); + return INSTANCE; +} + YY_BREAK +case 38: +YY_RULE_SETUP +#line 470 "lexer.lxx" +{ + accept(); + return LINE; +} + YY_BREAK +case 39: +YY_RULE_SETUP +#line 474 "lexer.lxx" +{ + accept(); + return LOOP; +} + YY_BREAK +case 40: +YY_RULE_SETUP +#line 478 "lexer.lxx" +{ + accept(); + return MATERIAL; +} + YY_BREAK +case 41: +YY_RULE_SETUP +#line 482 "lexer.lxx" +{ + accept(); + return MATRIX3; +} + YY_BREAK +case 42: +YY_RULE_SETUP +#line 486 "lexer.lxx" +{ + accept(); + return MATRIX4; +} + YY_BREAK +case 43: +YY_RULE_SETUP +#line 490 "lexer.lxx" +{ + accept(); + return MODEL; +} + YY_BREAK +case 44: +YY_RULE_SETUP +#line 494 "lexer.lxx" +{ + accept(); + return MREF; +} + YY_BREAK +case 45: +YY_RULE_SETUP +#line 498 "lexer.lxx" +{ + accept(); + return NORMAL; +} + YY_BREAK +case 46: +YY_RULE_SETUP +#line 502 "lexer.lxx" +{ + accept(); + return NURBSCURVE; +} + YY_BREAK +case 47: +YY_RULE_SETUP +#line 506 "lexer.lxx" +{ + accept(); + return NURBSSURFACE; +} + YY_BREAK +case 48: +YY_RULE_SETUP +#line 510 "lexer.lxx" +{ + accept(); + return OBJECTTYPE; +} + YY_BREAK +case 49: +YY_RULE_SETUP +#line 514 "lexer.lxx" +{ + accept(); + return ORDER; +} + YY_BREAK +case 50: +YY_RULE_SETUP +#line 518 "lexer.lxx" +{ + accept(); + return OUTTANGENT; +} + YY_BREAK +case 51: +YY_RULE_SETUP +#line 522 "lexer.lxx" +{ + accept(); + return POINTLIGHT; +} + YY_BREAK +case 52: +YY_RULE_SETUP +#line 526 "lexer.lxx" +{ + accept(); + return POLYGON; +} + YY_BREAK +case 53: +YY_RULE_SETUP +#line 530 "lexer.lxx" +{ + accept(); + return REF; +} + YY_BREAK +case 54: +YY_RULE_SETUP +#line 534 "lexer.lxx" +{ + accept(); + return RGBA; +} + YY_BREAK +case 55: +YY_RULE_SETUP +#line 538 "lexer.lxx" +{ + accept(); + return ROTATE; +} + YY_BREAK +case 56: +YY_RULE_SETUP +#line 542 "lexer.lxx" +{ + accept(); + return ROTX; +} + YY_BREAK +case 57: +YY_RULE_SETUP +#line 546 "lexer.lxx" +{ + accept(); + return ROTY; +} + YY_BREAK +case 58: +YY_RULE_SETUP +#line 550 "lexer.lxx" +{ + accept(); + return ROTZ; +} + YY_BREAK +case 59: +YY_RULE_SETUP +#line 554 "lexer.lxx" +{ + accept(); + return SANIM; +} + YY_BREAK +case 60: +YY_RULE_SETUP +#line 558 "lexer.lxx" +{ + accept(); + return SCALAR; +} + YY_BREAK +case 61: +YY_RULE_SETUP +#line 562 "lexer.lxx" +{ + accept(); + return SCALE; +} + YY_BREAK +case 62: +YY_RULE_SETUP +#line 566 "lexer.lxx" +{ + accept(); + return SEQUENCE; +} + YY_BREAK +case 63: +YY_RULE_SETUP +#line 570 "lexer.lxx" +{ + accept(); + return SHADING; +} + YY_BREAK +case 64: +YY_RULE_SETUP +#line 574 "lexer.lxx" +{ + accept(); + return SWITCH; +} + YY_BREAK +case 65: +YY_RULE_SETUP +#line 578 "lexer.lxx" +{ + accept(); + return SWITCHCONDITION; +} + YY_BREAK +case 66: +YY_RULE_SETUP +#line 582 "lexer.lxx" +{ + accept(); + return TABLE; +} + YY_BREAK +case 67: +YY_RULE_SETUP +#line 586 "lexer.lxx" +{ + accept(); + return TABLE_V; +} + YY_BREAK +case 68: +YY_RULE_SETUP +#line 590 "lexer.lxx" +{ + accept(); + return TAG; +} + YY_BREAK +case 69: +YY_RULE_SETUP +#line 594 "lexer.lxx" +{ + accept(); + return TANGENT; +} + YY_BREAK +case 70: +YY_RULE_SETUP +#line 598 "lexer.lxx" +{ + accept(); + return TEXLIST; +} + YY_BREAK +case 71: +YY_RULE_SETUP +#line 602 "lexer.lxx" +{ + accept(); + return TEXTURE; +} + YY_BREAK +case 72: +YY_RULE_SETUP +#line 606 "lexer.lxx" +{ + accept(); + return TLENGTHS; +} + YY_BREAK +case 73: +YY_RULE_SETUP +#line 610 "lexer.lxx" +{ + accept(); + return TRANSFORM; +} + YY_BREAK +case 74: +YY_RULE_SETUP +#line 614 "lexer.lxx" +{ + accept(); + return TRANSLATE; +} + YY_BREAK +case 75: +YY_RULE_SETUP +#line 618 "lexer.lxx" +{ + accept(); + return TREF; +} + YY_BREAK +case 76: +YY_RULE_SETUP +#line 622 "lexer.lxx" +{ + accept(); + return TRIANGLEFAN; +} + YY_BREAK +case 77: +YY_RULE_SETUP +#line 626 "lexer.lxx" +{ + accept(); + return TRIANGLESTRIP; +} + YY_BREAK +case 78: +YY_RULE_SETUP +#line 630 "lexer.lxx" +{ + accept(); + return TRIM; +} + YY_BREAK +case 79: +YY_RULE_SETUP +#line 634 "lexer.lxx" +{ + accept(); + return TXT; +} + YY_BREAK +case 80: +YY_RULE_SETUP +#line 638 "lexer.lxx" +{ + accept(); + return UKNOTS; +} + YY_BREAK +case 81: +YY_RULE_SETUP +#line 642 "lexer.lxx" +{ + accept(); + return UKNOTS; +} + YY_BREAK +case 82: +YY_RULE_SETUP +#line 646 "lexer.lxx" +{ + accept(); + return UV; +} + YY_BREAK +case 83: +YY_RULE_SETUP +#line 650 "lexer.lxx" +{ + accept(); + return VKNOTS; +} + YY_BREAK +case 84: +YY_RULE_SETUP +#line 654 "lexer.lxx" +{ + accept(); + return VKNOTS; +} + YY_BREAK +case 85: +YY_RULE_SETUP +#line 658 "lexer.lxx" +{ + accept(); + return VERTEX; +} + YY_BREAK +case 86: +YY_RULE_SETUP +#line 662 "lexer.lxx" +{ + accept(); + return VERTEXANIM; +} + YY_BREAK +case 87: +YY_RULE_SETUP +#line 666 "lexer.lxx" +{ + accept(); + return VERTEXPOOL; +} + YY_BREAK +case 88: +YY_RULE_SETUP +#line 670 "lexer.lxx" +{ + accept(); + return VERTEXREF; +} + YY_BREAK +case 89: +YY_RULE_SETUP +#line 674 "lexer.lxx" +{ + accept(); + return XFMANIM; +} + YY_BREAK +case 90: +YY_RULE_SETUP +#line 678 "lexer.lxx" +{ + accept(); + return XFMSANIM; +} + YY_BREAK +case 91: +YY_RULE_SETUP +#line 685 "lexer.lxx" +{ + // An integer or floating-point number. + accept(); + eggyylval._number = atof(eggyytext); + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 92: +YY_RULE_SETUP +#line 693 "lexer.lxx" +{ + // A hexadecimal integer number. + accept(); + eggyylval._ulong = strtoul(yytext+2, NULL, 16); + eggyylval._string = yytext; + return EGG_ULONG; +} + YY_BREAK +case 93: +YY_RULE_SETUP +#line 701 "lexer.lxx" +{ + // A binary integer number. + accept(); + eggyylval._ulong = strtoul(yytext+2, NULL, 2); + eggyylval._string = yytext; + return EGG_ULONG; +} + YY_BREAK +case 94: +YY_RULE_SETUP +#line 709 "lexer.lxx" +{ + // not-a-number. These sometimes show up in egg files accidentally. + accept(); + memset(&eggyylval._number, 0, sizeof(eggyylval._number)); + *(unsigned long *)&eggyylval._number = strtoul(yytext+3, NULL, 0); + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 95: +YY_RULE_SETUP +#line 718 "lexer.lxx" +{ + // infinity. As above. + accept(); + eggyylval._number = HUGE_VAL; + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 96: +YY_RULE_SETUP +#line 726 "lexer.lxx" +{ + // minus infinity. As above. + accept(); + eggyylval._number = -HUGE_VAL; + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 97: +YY_RULE_SETUP +#line 734 "lexer.lxx" +{ + // infinity, on Win32. As above. + accept(); + eggyylval._number = HUGE_VAL; + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 98: +YY_RULE_SETUP +#line 742 "lexer.lxx" +{ + // minus infinity, on Win32. As above. + accept(); + eggyylval._number = -HUGE_VAL; + eggyylval._string = yytext; + return EGG_NUMBER; +} + YY_BREAK +case 99: +YY_RULE_SETUP +#line 751 "lexer.lxx" +{ + // Quoted string. + accept(); + eggyylval._string = scan_quoted_string(); + return EGG_STRING; +} + YY_BREAK +case 100: +YY_RULE_SETUP +#line 758 "lexer.lxx" +{ + // Unquoted string. + accept(); + eggyylval._string = yytext; + return EGG_STRING; +} + YY_BREAK +case 101: +YY_RULE_SETUP +#line 764 "lexer.lxx" +ECHO; + YY_BREAK +#line 2112 "lex.yy.c" +case YY_STATE_EOF(INITIAL): + yyterminate(); + + case YY_END_OF_BUFFER: + { + /* Amount of text matched not including the EOB char. */ + int yy_amount_of_matched_text = (int) (yy_cp - yytext_ptr) - 1; + + /* Undo the effects of YY_DO_BEFORE_ACTION. */ + *yy_cp = yy_hold_char; + YY_RESTORE_YY_MORE_OFFSET + + if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_NEW ) + { + /* We're scanning a new file or input source. It's + * possible that this happened because the user + * just pointed yyin at a new source and called + * yylex(). If so, then we have to assure + * consistency between yy_current_buffer and our + * globals. Here is the right place to do so, because + * this is the first action (other than possibly a + * back-up) that will match for the new input source. + */ + yy_n_chars = yy_current_buffer->yy_n_chars; + yy_current_buffer->yy_input_file = yyin; + yy_current_buffer->yy_buffer_status = YY_BUFFER_NORMAL; + } + + /* Note that here we test for yy_c_buf_p "<=" to the position + * of the first EOB in the buffer, since yy_c_buf_p will + * already have been incremented past the NUL character + * (since all states make transitions on EOB to the + * end-of-buffer state). Contrast this with the test + * in input(). + */ + if ( yy_c_buf_p <= &yy_current_buffer->yy_ch_buf[yy_n_chars] ) + { /* This was really a NUL. */ + yy_state_type yy_next_state; + + yy_c_buf_p = yytext_ptr + yy_amount_of_matched_text; + + yy_current_state = yy_get_previous_state(); + + /* Okay, we're now positioned to make the NUL + * transition. We couldn't have + * yy_get_previous_state() go ahead and do it + * for us because it doesn't know how to deal + * with the possibility of jamming (and we don't + * want to build jamming into it because then it + * will run more slowly). + */ + + yy_next_state = yy_try_NUL_trans( yy_current_state ); + + yy_bp = yytext_ptr + YY_MORE_ADJ; + + if ( yy_next_state ) + { + /* Consume the NUL. */ + yy_cp = ++yy_c_buf_p; + yy_current_state = yy_next_state; + goto yy_match; + } + + else + { + yy_cp = yy_c_buf_p; + goto yy_find_action; + } + } + + else switch ( yy_get_next_buffer() ) + { + case EOB_ACT_END_OF_FILE: + { + yy_did_buffer_switch_on_eof = 0; + + if ( yywrap() ) + { + /* Note: because we've taken care in + * yy_get_next_buffer() to have set up + * yytext, we can now set up + * yy_c_buf_p so that if some total + * hoser (like flex itself) wants to + * call the scanner after we return the + * YY_NULL, it'll still work - another + * YY_NULL will get returned. + */ + yy_c_buf_p = yytext_ptr + YY_MORE_ADJ; + + yy_act = YY_STATE_EOF(YY_START); + goto do_action; + } + + else + { + if ( ! yy_did_buffer_switch_on_eof ) + YY_NEW_FILE; + } + break; + } + + case EOB_ACT_CONTINUE_SCAN: + yy_c_buf_p = + yytext_ptr + yy_amount_of_matched_text; + + yy_current_state = yy_get_previous_state(); + + yy_cp = yy_c_buf_p; + yy_bp = yytext_ptr + YY_MORE_ADJ; + goto yy_match; + + case EOB_ACT_LAST_MATCH: + yy_c_buf_p = + &yy_current_buffer->yy_ch_buf[yy_n_chars]; + + yy_current_state = yy_get_previous_state(); + + yy_cp = yy_c_buf_p; + yy_bp = yytext_ptr + YY_MORE_ADJ; + goto yy_find_action; + } + break; + } + + default: + YY_FATAL_ERROR( + "fatal flex scanner internal error--no action found" ); + } /* end of action switch */ + } /* end of scanning one token */ + } /* end of yylex */ + + +/* yy_get_next_buffer - try to read in a new buffer + * + * Returns a code representing an action: + * EOB_ACT_LAST_MATCH - + * EOB_ACT_CONTINUE_SCAN - continue scanning from current position + * EOB_ACT_END_OF_FILE - end of file + */ + +static int yy_get_next_buffer() + { + register char *dest = yy_current_buffer->yy_ch_buf; + register char *source = yytext_ptr; + register int number_to_move, i; + int ret_val; + + if ( yy_c_buf_p > &yy_current_buffer->yy_ch_buf[yy_n_chars + 1] ) + YY_FATAL_ERROR( + "fatal flex scanner internal error--end of buffer missed" ); + + if ( yy_current_buffer->yy_fill_buffer == 0 ) + { /* Don't try to fill the buffer, so this is an EOF. */ + if ( yy_c_buf_p - yytext_ptr - YY_MORE_ADJ == 1 ) + { + /* We matched a single character, the EOB, so + * treat this as a final EOF. + */ + return EOB_ACT_END_OF_FILE; + } + + else + { + /* We matched some text prior to the EOB, first + * process it. + */ + return EOB_ACT_LAST_MATCH; + } + } + + /* Try to read more data. */ + + /* First move last chars to start of buffer. */ + number_to_move = (int) (yy_c_buf_p - yytext_ptr) - 1; + + for ( i = 0; i < number_to_move; ++i ) + *(dest++) = *(source++); + + if ( yy_current_buffer->yy_buffer_status == YY_BUFFER_EOF_PENDING ) + /* don't do the read, it's not guaranteed to return an EOF, + * just force an EOF + */ + yy_current_buffer->yy_n_chars = yy_n_chars = 0; + + else + { + int num_to_read = + yy_current_buffer->yy_buf_size - number_to_move - 1; + + while ( num_to_read <= 0 ) + { /* Not enough room in the buffer - grow it. */ +#ifdef YY_USES_REJECT + YY_FATAL_ERROR( +"input buffer overflow, can't enlarge buffer because scanner uses REJECT" ); +#else + + /* just a shorter name for the current buffer */ + YY_BUFFER_STATE b = yy_current_buffer; + + int yy_c_buf_p_offset = + (int) (yy_c_buf_p - b->yy_ch_buf); + + if ( b->yy_is_our_buffer ) + { + int new_size = b->yy_buf_size * 2; + + if ( new_size <= 0 ) + b->yy_buf_size += b->yy_buf_size / 8; + else + b->yy_buf_size *= 2; + + b->yy_ch_buf = (char *) + /* Include room in for 2 EOB chars. */ + yy_flex_realloc( (void *) b->yy_ch_buf, + b->yy_buf_size + 2 ); + } + else + /* Can't grow it, we don't own it. */ + b->yy_ch_buf = 0; + + if ( ! b->yy_ch_buf ) + YY_FATAL_ERROR( + "fatal error - scanner input buffer overflow" ); + + yy_c_buf_p = &b->yy_ch_buf[yy_c_buf_p_offset]; + + num_to_read = yy_current_buffer->yy_buf_size - + number_to_move - 1; +#endif + } + + if ( num_to_read > YY_READ_BUF_SIZE ) + num_to_read = YY_READ_BUF_SIZE; + + /* Read in more data. */ + YY_INPUT( (&yy_current_buffer->yy_ch_buf[number_to_move]), + yy_n_chars, num_to_read ); + + yy_current_buffer->yy_n_chars = yy_n_chars; + } + + if ( yy_n_chars == 0 ) + { + if ( number_to_move == YY_MORE_ADJ ) + { + ret_val = EOB_ACT_END_OF_FILE; + yyrestart( yyin ); + } + + else + { + ret_val = EOB_ACT_LAST_MATCH; + yy_current_buffer->yy_buffer_status = + YY_BUFFER_EOF_PENDING; + } + } + + else + ret_val = EOB_ACT_CONTINUE_SCAN; + + yy_n_chars += number_to_move; + yy_current_buffer->yy_ch_buf[yy_n_chars] = YY_END_OF_BUFFER_CHAR; + yy_current_buffer->yy_ch_buf[yy_n_chars + 1] = YY_END_OF_BUFFER_CHAR; + + yytext_ptr = &yy_current_buffer->yy_ch_buf[0]; + + return ret_val; + } + + +/* yy_get_previous_state - get the state just before the EOB char was reached */ + +static yy_state_type yy_get_previous_state() + { + register yy_state_type yy_current_state; + register char *yy_cp; + + yy_current_state = yy_start; + + for ( yy_cp = yytext_ptr + YY_MORE_ADJ; yy_cp < yy_c_buf_p; ++yy_cp ) + { + register YY_CHAR yy_c = (*yy_cp ? yy_ec[YY_SC_TO_UI(*yy_cp)] : 1); + if ( yy_accept[yy_current_state] ) + { + yy_last_accepting_state = yy_current_state; + yy_last_accepting_cpos = yy_cp; + } + while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) + { + yy_current_state = (int) yy_def[yy_current_state]; + if ( yy_current_state >= 581 ) + yy_c = yy_meta[(unsigned int) yy_c]; + } + yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; + } + + return yy_current_state; + } + + +/* yy_try_NUL_trans - try to make a transition on the NUL character + * + * synopsis + * next_state = yy_try_NUL_trans( current_state ); + */ + +#ifdef YY_USE_PROTOS +static yy_state_type yy_try_NUL_trans( yy_state_type yy_current_state ) +#else +static yy_state_type yy_try_NUL_trans( yy_current_state ) +yy_state_type yy_current_state; +#endif + { + register int yy_is_jam; + register char *yy_cp = yy_c_buf_p; + + register YY_CHAR yy_c = 1; + if ( yy_accept[yy_current_state] ) + { + yy_last_accepting_state = yy_current_state; + yy_last_accepting_cpos = yy_cp; + } + while ( yy_chk[yy_base[yy_current_state] + yy_c] != yy_current_state ) + { + yy_current_state = (int) yy_def[yy_current_state]; + if ( yy_current_state >= 581 ) + yy_c = yy_meta[(unsigned int) yy_c]; + } + yy_current_state = yy_nxt[yy_base[yy_current_state] + (unsigned int) yy_c]; + yy_is_jam = (yy_current_state == 580); + + return yy_is_jam ? 0 : yy_current_state; + } + + +#ifndef YY_NO_UNPUT +#ifdef YY_USE_PROTOS +static void yyunput( int c, register char *yy_bp ) +#else +static void yyunput( c, yy_bp ) +int c; +register char *yy_bp; +#endif + { + register char *yy_cp = yy_c_buf_p; + + /* undo effects of setting up yytext */ + *yy_cp = yy_hold_char; + + if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 ) + { /* need to shift things up to make room */ + /* +2 for EOB chars. */ + register int number_to_move = yy_n_chars + 2; + register char *dest = &yy_current_buffer->yy_ch_buf[ + yy_current_buffer->yy_buf_size + 2]; + register char *source = + &yy_current_buffer->yy_ch_buf[number_to_move]; + + while ( source > yy_current_buffer->yy_ch_buf ) + *--dest = *--source; + + yy_cp += (int) (dest - source); + yy_bp += (int) (dest - source); + yy_current_buffer->yy_n_chars = + yy_n_chars = yy_current_buffer->yy_buf_size; + + if ( yy_cp < yy_current_buffer->yy_ch_buf + 2 ) + YY_FATAL_ERROR( "flex scanner push-back overflow" ); + } + + *--yy_cp = (char) c; + + + yytext_ptr = yy_bp; + yy_hold_char = *yy_cp; + yy_c_buf_p = yy_cp; + } +#endif /* ifndef YY_NO_UNPUT */ + + +#ifdef __cplusplus +static int yyinput() +#else +static int input() +#endif + { + int c; + + *yy_c_buf_p = yy_hold_char; + + if ( *yy_c_buf_p == YY_END_OF_BUFFER_CHAR ) + { + /* yy_c_buf_p now points to the character we want to return. + * If this occurs *before* the EOB characters, then it's a + * valid NUL; if not, then we've hit the end of the buffer. + */ + if ( yy_c_buf_p < &yy_current_buffer->yy_ch_buf[yy_n_chars] ) + /* This was really a NUL. */ + *yy_c_buf_p = '\0'; + + else + { /* need more input */ + int offset = yy_c_buf_p - yytext_ptr; + ++yy_c_buf_p; + + switch ( yy_get_next_buffer() ) + { + case EOB_ACT_LAST_MATCH: + /* This happens because yy_g_n_b() + * sees that we've accumulated a + * token and flags that we need to + * try matching the token before + * proceeding. But for input(), + * there's no matching to consider. + * So convert the EOB_ACT_LAST_MATCH + * to EOB_ACT_END_OF_FILE. + */ + + /* Reset buffer status. */ + yyrestart( yyin ); + + /* fall through */ + + case EOB_ACT_END_OF_FILE: + { + if ( yywrap() ) + return EOF; + + if ( ! yy_did_buffer_switch_on_eof ) + YY_NEW_FILE; +#ifdef __cplusplus + return yyinput(); +#else + return input(); +#endif + } + + case EOB_ACT_CONTINUE_SCAN: + yy_c_buf_p = yytext_ptr + offset; + break; + } + } + } + + c = *(unsigned char *) yy_c_buf_p; /* cast for 8-bit char's */ + *yy_c_buf_p = '\0'; /* preserve yytext */ + yy_hold_char = *++yy_c_buf_p; + + + return c; + } + + +#ifdef YY_USE_PROTOS +void yyrestart( FILE *input_file ) +#else +void yyrestart( input_file ) +FILE *input_file; +#endif + { + if ( ! yy_current_buffer ) + yy_current_buffer = yy_create_buffer( yyin, YY_BUF_SIZE ); + + yy_init_buffer( yy_current_buffer, input_file ); + yy_load_buffer_state(); + } + + +#ifdef YY_USE_PROTOS +void yy_switch_to_buffer( YY_BUFFER_STATE new_buffer ) +#else +void yy_switch_to_buffer( new_buffer ) +YY_BUFFER_STATE new_buffer; +#endif + { + if ( yy_current_buffer == new_buffer ) + return; + + if ( yy_current_buffer ) + { + /* Flush out information for old buffer. */ + *yy_c_buf_p = yy_hold_char; + yy_current_buffer->yy_buf_pos = yy_c_buf_p; + yy_current_buffer->yy_n_chars = yy_n_chars; + } + + yy_current_buffer = new_buffer; + yy_load_buffer_state(); + + /* We don't actually know whether we did this switch during + * EOF (yywrap()) processing, but the only time this flag + * is looked at is after yywrap() is called, so it's safe + * to go ahead and always set it. + */ + yy_did_buffer_switch_on_eof = 1; + } + + +#ifdef YY_USE_PROTOS +void yy_load_buffer_state( void ) +#else +void yy_load_buffer_state() +#endif + { + yy_n_chars = yy_current_buffer->yy_n_chars; + yytext_ptr = yy_c_buf_p = yy_current_buffer->yy_buf_pos; + yyin = yy_current_buffer->yy_input_file; + yy_hold_char = *yy_c_buf_p; + } + + +#ifdef YY_USE_PROTOS +YY_BUFFER_STATE yy_create_buffer( FILE *file, int size ) +#else +YY_BUFFER_STATE yy_create_buffer( file, size ) +FILE *file; +int size; +#endif + { + YY_BUFFER_STATE b; + + b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) ); + if ( ! b ) + YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); + + b->yy_buf_size = size; + + /* yy_ch_buf has to be 2 characters longer than the size given because + * we need to put in 2 end-of-buffer characters. + */ + b->yy_ch_buf = (char *) yy_flex_alloc( b->yy_buf_size + 2 ); + if ( ! b->yy_ch_buf ) + YY_FATAL_ERROR( "out of dynamic memory in yy_create_buffer()" ); + + b->yy_is_our_buffer = 1; + + yy_init_buffer( b, file ); + + return b; + } + + +#ifdef YY_USE_PROTOS +void yy_delete_buffer( YY_BUFFER_STATE b ) +#else +void yy_delete_buffer( b ) +YY_BUFFER_STATE b; +#endif + { + if ( ! b ) + return; + + if ( b == yy_current_buffer ) + yy_current_buffer = (YY_BUFFER_STATE) 0; + + if ( b->yy_is_our_buffer ) + yy_flex_free( (void *) b->yy_ch_buf ); + + yy_flex_free( (void *) b ); + } + + +#ifndef YY_ALWAYS_INTERACTIVE +#ifndef YY_NEVER_INTERACTIVE +extern int isatty YY_PROTO(( int )); +#endif +#endif + +#ifdef YY_USE_PROTOS +void yy_init_buffer( YY_BUFFER_STATE b, FILE *file ) +#else +void yy_init_buffer( b, file ) +YY_BUFFER_STATE b; +FILE *file; +#endif + + + { + yy_flush_buffer( b ); + + b->yy_input_file = file; + b->yy_fill_buffer = 1; + +#if YY_ALWAYS_INTERACTIVE + b->yy_is_interactive = 1; +#else +#if YY_NEVER_INTERACTIVE + b->yy_is_interactive = 0; +#else + b->yy_is_interactive = file ? (isatty( fileno(file) ) > 0) : 0; +#endif +#endif + } + + +#ifdef YY_USE_PROTOS +void yy_flush_buffer( YY_BUFFER_STATE b ) +#else +void yy_flush_buffer( b ) +YY_BUFFER_STATE b; +#endif + + { + if ( ! b ) + return; + + b->yy_n_chars = 0; + + /* We always need two end-of-buffer characters. The first causes + * a transition to the end-of-buffer state. The second causes + * a jam in that state. + */ + b->yy_ch_buf[0] = YY_END_OF_BUFFER_CHAR; + b->yy_ch_buf[1] = YY_END_OF_BUFFER_CHAR; + + b->yy_buf_pos = &b->yy_ch_buf[0]; + + b->yy_at_bol = 1; + b->yy_buffer_status = YY_BUFFER_NEW; + + if ( b == yy_current_buffer ) + yy_load_buffer_state(); + } + + +#ifndef YY_NO_SCAN_BUFFER +#ifdef YY_USE_PROTOS +YY_BUFFER_STATE yy_scan_buffer( char *base, yy_size_t size ) +#else +YY_BUFFER_STATE yy_scan_buffer( base, size ) +char *base; +yy_size_t size; +#endif + { + YY_BUFFER_STATE b; + + if ( size < 2 || + base[size-2] != YY_END_OF_BUFFER_CHAR || + base[size-1] != YY_END_OF_BUFFER_CHAR ) + /* They forgot to leave room for the EOB's. */ + return 0; + + b = (YY_BUFFER_STATE) yy_flex_alloc( sizeof( struct yy_buffer_state ) ); + if ( ! b ) + YY_FATAL_ERROR( "out of dynamic memory in yy_scan_buffer()" ); + + b->yy_buf_size = size - 2; /* "- 2" to take care of EOB's */ + b->yy_buf_pos = b->yy_ch_buf = base; + b->yy_is_our_buffer = 0; + b->yy_input_file = 0; + b->yy_n_chars = b->yy_buf_size; + b->yy_is_interactive = 0; + b->yy_at_bol = 1; + b->yy_fill_buffer = 0; + b->yy_buffer_status = YY_BUFFER_NEW; + + yy_switch_to_buffer( b ); + + return b; + } +#endif + + +#ifndef YY_NO_SCAN_STRING +#ifdef YY_USE_PROTOS +YY_BUFFER_STATE yy_scan_string( yyconst char *yy_str ) +#else +YY_BUFFER_STATE yy_scan_string( yy_str ) +yyconst char *yy_str; +#endif + { + int len; + for ( len = 0; yy_str[len]; ++len ) + ; + + return yy_scan_bytes( yy_str, len ); + } +#endif + + +#ifndef YY_NO_SCAN_BYTES +#ifdef YY_USE_PROTOS +YY_BUFFER_STATE yy_scan_bytes( yyconst char *bytes, int len ) +#else +YY_BUFFER_STATE yy_scan_bytes( bytes, len ) +yyconst char *bytes; +int len; +#endif + { + YY_BUFFER_STATE b; + char *buf; + yy_size_t n; + int i; + + /* Get memory for full buffer, including space for trailing EOB's. */ + n = len + 2; + buf = (char *) yy_flex_alloc( n ); + if ( ! buf ) + YY_FATAL_ERROR( "out of dynamic memory in yy_scan_bytes()" ); + + for ( i = 0; i < len; ++i ) + buf[i] = bytes[i]; + + buf[len] = buf[len+1] = YY_END_OF_BUFFER_CHAR; + + b = yy_scan_buffer( buf, n ); + if ( ! b ) + YY_FATAL_ERROR( "bad buffer in yy_scan_bytes()" ); + + /* It's okay to grow etc. this buffer, and we should throw it + * away when we're done. + */ + b->yy_is_our_buffer = 1; + + return b; + } +#endif + + +#ifndef YY_NO_PUSH_STATE +#ifdef YY_USE_PROTOS +static void yy_push_state( int new_state ) +#else +static void yy_push_state( new_state ) +int new_state; +#endif + { + if ( yy_start_stack_ptr >= yy_start_stack_depth ) + { + yy_size_t new_size; + + yy_start_stack_depth += YY_START_STACK_INCR; + new_size = yy_start_stack_depth * sizeof( int ); + + if ( ! yy_start_stack ) + yy_start_stack = (int *) yy_flex_alloc( new_size ); + + else + yy_start_stack = (int *) yy_flex_realloc( + (void *) yy_start_stack, new_size ); + + if ( ! yy_start_stack ) + YY_FATAL_ERROR( + "out of memory expanding start-condition stack" ); + } + + yy_start_stack[yy_start_stack_ptr++] = YY_START; + + BEGIN(new_state); + } +#endif + + +#ifndef YY_NO_POP_STATE +static void yy_pop_state() + { + if ( --yy_start_stack_ptr < 0 ) + YY_FATAL_ERROR( "start-condition stack underflow" ); + + BEGIN(yy_start_stack[yy_start_stack_ptr]); + } +#endif + + +#ifndef YY_NO_TOP_STATE +static int yy_top_state() + { + return yy_start_stack[yy_start_stack_ptr - 1]; + } +#endif + +#ifndef YY_EXIT_FAILURE +#define YY_EXIT_FAILURE 2 +#endif + +#ifdef YY_USE_PROTOS +static void yy_fatal_error( yyconst char msg[] ) +#else +static void yy_fatal_error( msg ) +char msg[]; +#endif + { + (void) fprintf( stderr, "%s\n", msg ); + exit( YY_EXIT_FAILURE ); + } + + + +/* Redefine yyless() so it works in section 3 code. */ + +#undef yyless +#define yyless(n) \ + do \ + { \ + /* Undo effects of setting up yytext. */ \ + yytext[yyleng] = yy_hold_char; \ + yy_c_buf_p = yytext + n; \ + yy_hold_char = *yy_c_buf_p; \ + *yy_c_buf_p = '\0'; \ + yyleng = n; \ + } \ + while ( 0 ) + + +/* Internal utility routines. */ + +#ifndef yytext_ptr +#ifdef YY_USE_PROTOS +static void yy_flex_strncpy( char *s1, yyconst char *s2, int n ) +#else +static void yy_flex_strncpy( s1, s2, n ) +char *s1; +yyconst char *s2; +int n; +#endif + { + register int i; + for ( i = 0; i < n; ++i ) + s1[i] = s2[i]; + } +#endif + +#ifdef YY_NEED_STRLEN +#ifdef YY_USE_PROTOS +static int yy_flex_strlen( yyconst char *s ) +#else +static int yy_flex_strlen( s ) +yyconst char *s; +#endif + { + register int n; + for ( n = 0; s[n]; ++n ) + ; + + return n; + } +#endif + + +#ifdef YY_USE_PROTOS +static void *yy_flex_alloc( yy_size_t size ) +#else +static void *yy_flex_alloc( size ) +yy_size_t size; +#endif + { + return (void *) malloc( size ); + } + +#ifdef YY_USE_PROTOS +static void *yy_flex_realloc( void *ptr, yy_size_t size ) +#else +static void *yy_flex_realloc( ptr, size ) +void *ptr; +yy_size_t size; +#endif + { + /* The cast to (char *) in the following accommodates both + * implementations that use char* generic pointers, and those + * that use void* generic pointers. It works with the latter + * because both ANSI C and C++ allow castless assignment from + * any pointer type to void*, and deal with argument conversions + * as though doing an assignment. + */ + return (void *) realloc( (char *) ptr, size ); + } + +#ifdef YY_USE_PROTOS +static void yy_flex_free( void *ptr ) +#else +static void yy_flex_free( ptr ) +void *ptr; +#endif + { + free( ptr ); + } + +#if YY_MAIN +int main() + { + yylex(); + return 0; + } +#endif +#line 764 "lexer.lxx" diff --git a/panda/src/egg/lexer.lxx b/panda/src/egg/lexer.lxx index b212ff5782..5f40ac590a 100644 --- a/panda/src/egg/lexer.lxx +++ b/panda/src/egg/lexer.lxx @@ -339,6 +339,10 @@ NUMERIC ([+-]?(([0-9]+[.]?)|([0-9]*[.][0-9]+))([eE][+-]?[0-9]+)?) +"" { + accept(); + return ANIMPRELOAD; +} "" { accept(); return BEZIERCURVE; diff --git a/panda/src/egg/parser.cxx.prebuilt b/panda/src/egg/parser.cxx.prebuilt index 98228def5a..16b382f671 100644 --- a/panda/src/egg/parser.cxx.prebuilt +++ b/panda/src/egg/parser.cxx.prebuilt @@ -1,263 +1,106 @@ -/* A Bison parser, made by GNU Bison 2.3. */ -/* Skeleton implementation for Bison's Yacc-like parsers in C +/* A Bison parser, made from parser.yxx + by GNU Bison version 1.28 */ - Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - Free Software Foundation, Inc. +#define YYBISON 1 /* Identify Bison output. */ - 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. */ - -/* As a special exception, you may create a larger work that contains - part or all of the Bison parser skeleton and distribute that work - under terms of your choice, so long as that work isn't itself a - parser generator using the skeleton or a modified version thereof - as a parser skeleton. Alternatively, if you modify or redistribute - the parser skeleton itself, you may (at your option) remove this - special exception, which will cause the skeleton and the resulting - Bison output files to be licensed under the GNU General Public - License without this special exception. - - This special exception was added by the Free Software Foundation in - version 2.2 of Bison. */ - -/* C LALR(1) parser skeleton written by Richard Stallman, by - simplifying the original so-called "semantic" parser. */ - -/* All symbols defined below should begin with yy or YY, to avoid - infringing on user name space. This should be done even for local - variables, as they might otherwise be expanded by user macros. - There are some unavoidable exceptions within include files to - define necessary library symbols; they are noted "INFRINGES ON - USER NAME SPACE" below. */ - -/* Identify Bison output. */ -#define YYBISON 1 - -/* Bison version. */ -#define YYBISON_VERSION "2.3" - -/* Skeleton name. */ -#define YYSKELETON_NAME "yacc.c" - -/* Pure parsers. */ -#define YYPURE 0 - -/* Using locations. */ -#define YYLSP_NEEDED 0 - -/* Substitute the variable and function names. */ #define yyparse eggyyparse -#define yylex eggyylex +#define yylex eggyylex #define yyerror eggyyerror -#define yylval eggyylval -#define yychar eggyychar +#define yylval eggyylval +#define yychar eggyychar #define yydebug eggyydebug #define yynerrs eggyynerrs +#define EGG_NUMBER 257 +#define EGG_ULONG 258 +#define EGG_STRING 259 +#define ANIMPRELOAD 260 +#define BEZIERCURVE 261 +#define BFACE 262 +#define BILLBOARD 263 +#define BILLBOARDCENTER 264 +#define BINORMAL 265 +#define BUNDLE 266 +#define CLOSED 267 +#define COLLIDE 268 +#define COMMENT 269 +#define COMPONENT 270 +#define COORDSYSTEM 271 +#define CV 272 +#define DART 273 +#define DNORMAL 274 +#define DRGBA 275 +#define DUV 276 +#define DXYZ 277 +#define DCS 278 +#define DISTANCE 279 +#define DTREF 280 +#define DYNAMICVERTEXPOOL 281 +#define EXTERNAL_FILE 282 +#define FLIGHT 283 +#define GROUP 284 +#define HIP 285 +#define INTANGENT 286 +#define JOINT 287 +#define KNOTS 288 +#define INCLUDE 289 +#define INSTANCE 290 +#define LINE 291 +#define LOOP 292 +#define MATERIAL 293 +#define MATRIX3 294 +#define MATRIX4 295 +#define MODEL 296 +#define MREF 297 +#define NORMAL 298 +#define NURBSCURVE 299 +#define NURBSSURFACE 300 +#define OBJECTTYPE 301 +#define ORDER 302 +#define OUTTANGENT 303 +#define POINTLIGHT 304 +#define POLYGON 305 +#define REF 306 +#define RGBA 307 +#define ROTATE 308 +#define ROTX 309 +#define ROTY 310 +#define ROTZ 311 +#define SANIM 312 +#define SCALAR 313 +#define SCALE 314 +#define SEQUENCE 315 +#define SHADING 316 +#define SWITCH 317 +#define SWITCHCONDITION 318 +#define TABLE 319 +#define TABLE_V 320 +#define TAG 321 +#define TANGENT 322 +#define TEXLIST 323 +#define TEXTURE 324 +#define TLENGTHS 325 +#define TRANSFORM 326 +#define TRANSLATE 327 +#define TREF 328 +#define TRIANGLEFAN 329 +#define TRIANGLESTRIP 330 +#define TRIM 331 +#define TXT 332 +#define UKNOTS 333 +#define UV 334 +#define VKNOTS 335 +#define VERTEX 336 +#define VERTEXANIM 337 +#define VERTEXPOOL 338 +#define VERTEXREF 339 +#define XFMANIM 340 +#define XFMSANIM 341 +#define START_EGG 342 +#define START_GROUP_BODY 343 +#define START_TEXTURE_BODY 344 +#define START_PRIMITIVE_BODY 345 - -/* Tokens. */ -#ifndef YYTOKENTYPE -# define YYTOKENTYPE - /* Put the tokens into the symbol table, so that GDB and other debuggers - know about them. */ - enum yytokentype { - EGG_NUMBER = 258, - EGG_ULONG = 259, - EGG_STRING = 260, - BEZIERCURVE = 261, - BFACE = 262, - BILLBOARD = 263, - BILLBOARDCENTER = 264, - BINORMAL = 265, - BUNDLE = 266, - CLOSED = 267, - COLLIDE = 268, - COMMENT = 269, - COMPONENT = 270, - COORDSYSTEM = 271, - CV = 272, - DART = 273, - DNORMAL = 274, - DRGBA = 275, - DUV = 276, - DXYZ = 277, - DCS = 278, - DISTANCE = 279, - DTREF = 280, - DYNAMICVERTEXPOOL = 281, - EXTERNAL_FILE = 282, - FLIGHT = 283, - GROUP = 284, - HIP = 285, - INTANGENT = 286, - JOINT = 287, - KNOTS = 288, - INCLUDE = 289, - INSTANCE = 290, - LINE = 291, - LOOP = 292, - MATERIAL = 293, - MATRIX3 = 294, - MATRIX4 = 295, - MODEL = 296, - MREF = 297, - NORMAL = 298, - NURBSCURVE = 299, - NURBSSURFACE = 300, - OBJECTTYPE = 301, - ORDER = 302, - OUTTANGENT = 303, - POINTLIGHT = 304, - POLYGON = 305, - REF = 306, - RGBA = 307, - ROTATE = 308, - ROTX = 309, - ROTY = 310, - ROTZ = 311, - SANIM = 312, - SCALAR = 313, - SCALE = 314, - SEQUENCE = 315, - SHADING = 316, - SWITCH = 317, - SWITCHCONDITION = 318, - TABLE = 319, - TABLE_V = 320, - TAG = 321, - TANGENT = 322, - TEXLIST = 323, - TEXTURE = 324, - TLENGTHS = 325, - TRANSFORM = 326, - TRANSLATE = 327, - TREF = 328, - TRIANGLEFAN = 329, - TRIANGLESTRIP = 330, - TRIM = 331, - TXT = 332, - UKNOTS = 333, - UV = 334, - VKNOTS = 335, - VERTEX = 336, - VERTEXANIM = 337, - VERTEXPOOL = 338, - VERTEXREF = 339, - XFMANIM = 340, - XFMSANIM = 341, - START_EGG = 342, - START_GROUP_BODY = 343, - START_TEXTURE_BODY = 344, - START_PRIMITIVE_BODY = 345 - }; -#endif -/* Tokens. */ -#define EGG_NUMBER 258 -#define EGG_ULONG 259 -#define EGG_STRING 260 -#define BEZIERCURVE 261 -#define BFACE 262 -#define BILLBOARD 263 -#define BILLBOARDCENTER 264 -#define BINORMAL 265 -#define BUNDLE 266 -#define CLOSED 267 -#define COLLIDE 268 -#define COMMENT 269 -#define COMPONENT 270 -#define COORDSYSTEM 271 -#define CV 272 -#define DART 273 -#define DNORMAL 274 -#define DRGBA 275 -#define DUV 276 -#define DXYZ 277 -#define DCS 278 -#define DISTANCE 279 -#define DTREF 280 -#define DYNAMICVERTEXPOOL 281 -#define EXTERNAL_FILE 282 -#define FLIGHT 283 -#define GROUP 284 -#define HIP 285 -#define INTANGENT 286 -#define JOINT 287 -#define KNOTS 288 -#define INCLUDE 289 -#define INSTANCE 290 -#define LINE 291 -#define LOOP 292 -#define MATERIAL 293 -#define MATRIX3 294 -#define MATRIX4 295 -#define MODEL 296 -#define MREF 297 -#define NORMAL 298 -#define NURBSCURVE 299 -#define NURBSSURFACE 300 -#define OBJECTTYPE 301 -#define ORDER 302 -#define OUTTANGENT 303 -#define POINTLIGHT 304 -#define POLYGON 305 -#define REF 306 -#define RGBA 307 -#define ROTATE 308 -#define ROTX 309 -#define ROTY 310 -#define ROTZ 311 -#define SANIM 312 -#define SCALAR 313 -#define SCALE 314 -#define SEQUENCE 315 -#define SHADING 316 -#define SWITCH 317 -#define SWITCHCONDITION 318 -#define TABLE 319 -#define TABLE_V 320 -#define TAG 321 -#define TANGENT 322 -#define TEXLIST 323 -#define TEXTURE 324 -#define TLENGTHS 325 -#define TRANSFORM 326 -#define TRANSLATE 327 -#define TREF 328 -#define TRIANGLEFAN 329 -#define TRIANGLESTRIP 330 -#define TRIM 331 -#define TXT 332 -#define UKNOTS 333 -#define UV 334 -#define VKNOTS 335 -#define VERTEX 336 -#define VERTEXANIM 337 -#define VERTEXPOOL 338 -#define VERTEXREF 339 -#define XFMANIM 340 -#define XFMSANIM 341 -#define START_EGG 342 -#define START_GROUP_BODY 343 -#define START_TEXTURE_BODY 344 -#define START_PRIMITIVE_BODY 345 - - - - -/* Copy the first part of user declarations. */ #line 6 "parser.yxx" @@ -288,6 +131,7 @@ #include "eggCoordinateSystem.h" #include "eggExternalReference.h" #include "eggData.h" +#include "eggAnimPreload.h" #include "pt_EggTexture.h" #include "pt_EggMaterial.h" @@ -396,1802 +240,1104 @@ egg_cleanup_parser() { materials.clear(); } +#include - -/* Enabling traces. */ -#ifndef YYDEBUG -# define YYDEBUG 0 +#ifndef __cplusplus +#ifndef __STDC__ +#define const +#endif #endif -/* Enabling verbose error messages. */ -#ifdef YYERROR_VERBOSE -# undef YYERROR_VERBOSE -# define YYERROR_VERBOSE 1 + + +#define YYFINAL 735 +#define YYFLAG -32768 +#define YYNTBASE 94 + +#define YYTRANSLATE(x) ((unsigned)(x) <= 345 ? yytranslate[x] : 213) + +static const char yytranslate[] = { 0, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 92, 2, 93, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 2, 2, 2, 2, 1, 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, 39, 40, 41, 42, 43, 44, 45, 46, + 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, + 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, + 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, + 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, + 87, 88, 89, 90, 91 +}; + +#if YYDEBUG != 0 +static const short yyprhs[] = { 0, + 0, 3, 6, 9, 12, 14, 17, 19, 21, 23, + 25, 27, 29, 31, 33, 35, 37, 39, 41, 43, + 45, 47, 49, 51, 53, 58, 64, 65, 73, 75, + 82, 85, 86, 93, 95, 102, 108, 115, 116, 123, + 125, 128, 129, 135, 136, 143, 145, 148, 152, 157, + 158, 166, 172, 178, 187, 196, 199, 203, 211, 219, + 227, 236, 244, 253, 257, 266, 275, 280, 290, 300, + 301, 308, 309, 316, 317, 324, 326, 333, 339, 347, + 355, 361, 367, 373, 379, 385, 391, 397, 404, 410, + 413, 416, 419, 422, 424, 426, 429, 430, 436, 438, + 441, 444, 447, 450, 453, 456, 459, 462, 465, 468, + 471, 474, 480, 487, 492, 497, 502, 507, 515, 521, + 528, 533, 538, 540, 550, 555, 557, 574, 584, 586, + 593, 598, 610, 623, 624, 631, 632, 639, 640, 647, + 648, 655, 656, 663, 664, 671, 672, 679, 681, 687, + 693, 695, 696, 704, 710, 716, 722, 725, 731, 737, + 743, 750, 752, 758, 764, 770, 773, 779, 785, 791, + 797, 803, 809, 812, 818, 825, 827, 833, 839, 845, + 848, 854, 860, 866, 872, 878, 885, 887, 889, 891, + 895, 904, 913, 918, 928, 938, 940, 949, 952, 954, + 956, 958, 964, 966, 969, 971, 973, 974, 981, 982, + 989, 991, 994, 997, 1000, 1003, 1006, 1007, 1014, 1016, + 1023, 1029, 1030, 1037, 1039, 1046, 1052, 1053, 1060, 1062, + 1069, 1072, 1073, 1080, 1082, 1089, 1091, 1094, 1096, 1099, + 1101, 1103, 1105, 1107, 1109, 1111, 1113, 1115, 1117, 1119, + 1121, 1123, 1125, 1127, 1129, 1131, 1134, 1136, 1138, 1140, + 1142, 1144, 1146, 1148 +}; + +static const short yyrhs[] = { 88, + 95, 0, 89, 123, 0, 90, 101, 0, 91, 162, + 0, 212, 0, 95, 96, 0, 97, 0, 98, 0, + 99, 0, 102, 0, 105, 0, 106, 0, 117, 0, + 119, 0, 121, 0, 147, 0, 149, 0, 151, 0, + 153, 0, 155, 0, 157, 0, 159, 0, 180, 0, + 194, 0, 17, 92, 204, 93, 0, 15, 203, 92, + 207, 93, 0, 0, 70, 202, 92, 204, 100, 101, + 93, 0, 212, 0, 101, 59, 202, 92, 210, 93, + 0, 101, 126, 0, 0, 39, 202, 92, 103, 104, + 93, 0, 212, 0, 104, 59, 202, 92, 210, 93, + 0, 28, 203, 92, 204, 93, 0, 206, 28, 203, + 92, 204, 93, 0, 0, 84, 202, 107, 92, 108, + 93, 0, 212, 0, 108, 109, 0, 0, 82, 110, + 92, 112, 93, 0, 0, 82, 211, 111, 92, 112, + 93, 0, 209, 0, 209, 209, 0, 209, 209, 209, + 0, 209, 209, 209, 209, 0, 0, 112, 80, 203, + 92, 113, 114, 93, 0, 112, 44, 92, 115, 93, + 0, 112, 53, 92, 116, 93, 0, 112, 23, 206, + 92, 209, 209, 209, 93, 0, 112, 23, 92, 206, + 209, 209, 209, 93, 0, 209, 209, 0, 209, 209, + 209, 0, 114, 68, 92, 209, 209, 209, 93, 0, + 114, 11, 92, 209, 209, 209, 93, 0, 114, 22, + 206, 92, 209, 209, 93, 0, 114, 22, 206, 92, + 209, 209, 209, 93, 0, 114, 22, 92, 206, 209, + 209, 93, 0, 114, 22, 92, 206, 209, 209, 209, + 93, 0, 209, 209, 209, 0, 115, 20, 206, 92, + 209, 209, 209, 93, 0, 115, 20, 92, 206, 209, + 209, 209, 93, 0, 209, 209, 209, 209, 0, 116, + 21, 206, 92, 209, 209, 209, 209, 93, 0, 116, + 21, 92, 206, 209, 209, 209, 209, 93, 0, 0, + 30, 203, 118, 92, 123, 93, 0, 0, 33, 203, + 120, 92, 123, 93, 0, 0, 36, 203, 122, 92, + 123, 93, 0, 212, 0, 123, 59, 202, 92, 210, + 93, 0, 123, 9, 92, 206, 93, 0, 123, 10, + 92, 209, 209, 209, 93, 0, 123, 14, 203, 92, + 124, 125, 93, 0, 123, 24, 92, 211, 93, 0, + 123, 24, 92, 5, 93, 0, 123, 19, 92, 211, + 93, 0, 123, 19, 92, 5, 93, 0, 123, 63, + 92, 211, 93, 0, 123, 47, 92, 204, 93, 0, + 123, 42, 92, 211, 93, 0, 123, 67, 203, 92, + 207, 93, 0, 123, 69, 92, 211, 93, 0, 123, + 126, 0, 123, 143, 0, 123, 145, 0, 123, 96, + 0, 206, 0, 212, 0, 125, 206, 0, 0, 72, + 127, 92, 128, 93, 0, 212, 0, 128, 129, 0, + 128, 130, 0, 128, 131, 0, 128, 132, 0, 128, + 133, 0, 128, 134, 0, 128, 135, 0, 128, 136, + 0, 128, 137, 0, 128, 138, 0, 128, 139, 0, + 128, 141, 0, 73, 92, 209, 209, 93, 0, 73, + 92, 209, 209, 209, 93, 0, 54, 92, 209, 93, + 0, 55, 92, 209, 93, 0, 56, 92, 209, 93, + 0, 57, 92, 209, 93, 0, 54, 92, 209, 209, + 209, 209, 93, 0, 60, 92, 209, 209, 93, 0, + 60, 92, 209, 209, 209, 93, 0, 60, 92, 209, + 93, 0, 40, 92, 140, 93, 0, 212, 0, 209, + 209, 209, 209, 209, 209, 209, 209, 209, 0, 41, + 92, 142, 93, 0, 212, 0, 209, 209, 209, 209, + 209, 209, 209, 209, 209, 209, 209, 209, 209, 209, + 209, 209, 0, 85, 92, 197, 144, 52, 92, 201, + 93, 93, 0, 212, 0, 144, 59, 202, 92, 210, + 93, 0, 64, 92, 146, 93, 0, 25, 92, 209, + 209, 82, 92, 209, 209, 209, 93, 93, 0, 25, + 92, 209, 209, 209, 82, 92, 209, 209, 209, 93, + 93, 0, 0, 51, 203, 148, 92, 162, 93, 0, + 0, 75, 203, 150, 92, 162, 93, 0, 0, 76, + 203, 152, 92, 162, 93, 0, 0, 50, 203, 154, + 92, 162, 93, 0, 0, 37, 203, 156, 92, 162, + 93, 0, 0, 46, 203, 158, 92, 164, 93, 0, + 0, 45, 203, 160, 92, 165, 93, 0, 212, 0, + 161, 44, 92, 169, 93, 0, 161, 53, 92, 170, + 93, 0, 212, 0, 0, 162, 16, 211, 92, 163, + 161, 93, 0, 162, 74, 92, 166, 93, 0, 162, + 70, 92, 167, 93, 0, 162, 43, 92, 168, 93, + 0, 162, 172, 0, 162, 44, 92, 169, 93, 0, + 162, 53, 92, 170, 93, 0, 162, 8, 92, 171, + 93, 0, 162, 59, 202, 92, 210, 93, 0, 212, + 0, 164, 74, 92, 166, 93, 0, 164, 70, 92, + 167, 93, 0, 164, 43, 92, 168, 93, 0, 164, + 172, 0, 164, 44, 92, 169, 93, 0, 164, 53, + 92, 170, 93, 0, 164, 8, 92, 171, 93, 0, + 164, 48, 92, 173, 93, 0, 164, 79, 92, 174, + 93, 0, 164, 81, 92, 175, 93, 0, 164, 159, + 0, 164, 77, 92, 176, 93, 0, 164, 59, 202, + 92, 210, 93, 0, 212, 0, 165, 74, 92, 166, + 93, 0, 165, 70, 92, 167, 93, 0, 165, 43, + 92, 168, 93, 0, 165, 172, 0, 165, 44, 92, + 169, 93, 0, 165, 53, 92, 170, 93, 0, 165, + 8, 92, 171, 93, 0, 165, 48, 92, 178, 93, + 0, 165, 34, 92, 179, 93, 0, 165, 59, 202, + 92, 210, 93, 0, 199, 0, 202, 0, 200, 0, + 209, 209, 209, 0, 169, 20, 206, 92, 209, 209, + 209, 93, 0, 169, 20, 92, 206, 209, 209, 209, + 93, 0, 209, 209, 209, 209, 0, 170, 21, 206, + 92, 209, 209, 209, 209, 93, 0, 170, 21, 92, + 206, 209, 209, 209, 209, 93, 0, 211, 0, 85, + 92, 197, 52, 92, 201, 93, 93, 0, 211, 211, + 0, 198, 0, 198, 0, 212, 0, 176, 38, 92, + 177, 93, 0, 212, 0, 177, 159, 0, 211, 0, + 198, 0, 0, 65, 203, 181, 92, 184, 93, 0, + 0, 12, 203, 183, 92, 184, 93, 0, 212, 0, + 184, 180, 0, 184, 182, 0, 184, 185, 0, 184, + 188, 0, 184, 191, 0, 0, 58, 203, 186, 92, + 187, 93, 0, 212, 0, 187, 59, 202, 92, 210, + 93, 0, 187, 66, 92, 198, 93, 0, 0, 86, + 203, 189, 92, 190, 93, 0, 212, 0, 190, 59, + 202, 92, 210, 93, 0, 190, 66, 92, 198, 93, + 0, 0, 87, 203, 192, 92, 193, 93, 0, 212, + 0, 193, 59, 202, 92, 210, 93, 0, 193, 185, + 0, 0, 6, 203, 195, 92, 196, 93, 0, 212, + 0, 196, 59, 202, 92, 210, 93, 0, 212, 0, + 197, 211, 0, 212, 0, 198, 209, 0, 202, 0, + 202, 0, 202, 0, 212, 0, 206, 0, 205, 0, + 212, 0, 206, 0, 212, 0, 206, 0, 3, 0, + 4, 0, 5, 0, 212, 0, 208, 0, 206, 0, + 208, 206, 0, 3, 0, 4, 0, 3, 0, 4, + 0, 5, 0, 3, 0, 4, 0, 0 +}; + +#endif + +#if YYDEBUG != 0 +static const short yyrline[] = { 0, + 218, 220, 221, 222, 232, 234, 249, 251, 252, 253, + 254, 255, 256, 257, 258, 259, 260, 261, 262, 263, + 264, 265, 266, 267, 277, 300, 314, 328, 342, 344, + 676, 686, 699, 713, 715, 809, 817, 836, 861, 876, + 878, 888, 893, 900, 925, 945, 950, 954, 958, 962, + 973, 977, 978, 979, 987, 1005, 1010, 1014, 1022, 1030, + 1038, 1046, 1054, 1071, 1076, 1084, 1101, 1106, 1114, 1131, + 1137, 1151, 1158, 1172, 1179, 1193, 1195, 1325, 1337, 1342, + 1349, 1355, 1368, 1375, 1388, 1394, 1400, 1406, 1411, 1417, + 1418, 1419, 1420, 1433, 1463, 1465, 1486, 1491, 1502, 1504, + 1505, 1506, 1507, 1508, 1509, 1510, 1511, 1512, 1513, 1514, + 1515, 1518, 1525, 1532, 1539, 1546, 1553, 1560, 1567, 1574, + 1581, 1588, 1592, 1594, 1605, 1609, 1611, 1632, 1665, 1670, + 1694, 1706, 1712, 1728, 1733, 1747, 1752, 1766, 1771, 1785, + 1790, 1804, 1809, 1823, 1828, 1842, 1847, 1862, 1864, 1865, + 1875, 1877, 1891, 1898, 1899, 1900, 1901, 1902, 1903, 1904, + 1905, 1977, 1979, 1980, 1981, 1982, 1983, 1984, 1985, 1986, + 1987, 1988, 1989, 1995, 1996, 2059, 2061, 2062, 2063, 2064, + 2065, 2066, 2067, 2068, 2069, 2070, 2138, 2155, 2195, 2212, + 2217, 2225, 2242, 2247, 2255, 2272, 2288, 2319, 2337, 2357, + 2377, 2383, 2393, 2400, 2418, 2434, 2455, 2462, 2477, 2484, + 2498, 2500, 2504, 2508, 2512, 2516, 2530, 2536, 2551, 2553, + 2565, 2578, 2584, 2599, 2601, 2618, 2631, 2637, 2652, 2654, + 2669, 2683, 2689, 2704, 2706, 2729, 2734, 2747, 2752, 2765, + 2786, 2807, 2833, 2839, 2850, 2862, 2868, 2878, 2883, 2896, + 2901, 2905, 2917, 2922, 2937, 2942, 2955, 2957, 2971, 2978, + 2984, 3000, 3009, 3015 +}; +#endif + + +#if YYDEBUG != 0 || defined (YYERROR_VERBOSE) + +static const char * const yytname[] = { "$","error","$undefined.","EGG_NUMBER", +"EGG_ULONG","EGG_STRING","ANIMPRELOAD","BEZIERCURVE","BFACE","BILLBOARD","BILLBOARDCENTER", +"BINORMAL","BUNDLE","CLOSED","COLLIDE","COMMENT","COMPONENT","COORDSYSTEM","CV", +"DART","DNORMAL","DRGBA","DUV","DXYZ","DCS","DISTANCE","DTREF","DYNAMICVERTEXPOOL", +"EXTERNAL_FILE","FLIGHT","GROUP","HIP","INTANGENT","JOINT","KNOTS","INCLUDE", +"INSTANCE","LINE","LOOP","MATERIAL","MATRIX3","MATRIX4","MODEL","MREF","NORMAL", +"NURBSCURVE","NURBSSURFACE","OBJECTTYPE","ORDER","OUTTANGENT","POINTLIGHT","POLYGON", +"REF","RGBA","ROTATE","ROTX","ROTY","ROTZ","SANIM","SCALAR","SCALE","SEQUENCE", +"SHADING","SWITCH","SWITCHCONDITION","TABLE","TABLE_V","TAG","TANGENT","TEXLIST", +"TEXTURE","TLENGTHS","TRANSFORM","TRANSLATE","TREF","TRIANGLEFAN","TRIANGLESTRIP", +"TRIM","TXT","UKNOTS","UV","VKNOTS","VERTEX","VERTEXANIM","VERTEXPOOL","VERTEXREF", +"XFMANIM","XFMSANIM","START_EGG","START_GROUP_BODY","START_TEXTURE_BODY","START_PRIMITIVE_BODY", +"'{'","'}'","grammar","egg","node","coordsystem","comment","texture","@1","texture_body", +"material","@2","material_body","external_reference","vertex_pool","@3","vertex_pool_body", +"vertex","@4","@5","vertex_body","@6","vertex_uv_body","vertex_normal_body", +"vertex_color_body","group","@7","joint","@8","instance","@9","group_body","cs_type", +"collide_flags","transform","@10","transform_body","translate2d","translate3d", +"rotate2d","rotx","roty","rotz","rotate3d","scale2d","scale3d","uniform_scale", +"matrix3","matrix3_body","matrix4","matrix4_body","group_vertex_ref","group_vertex_membership", +"switchcondition","switchcondition_body","polygon","@11","trianglefan","@12", +"trianglestrip","@13","point_light","@14","line","@15","nurbs_surface","@16", +"nurbs_curve","@17","primitive_component_body","primitive_body","@18","nurbs_surface_body", +"nurbs_curve_body","primitive_tref_body","primitive_texture_body","primitive_material_body", +"primitive_normal_body","primitive_color_body","primitive_bface_body","primitive_vertex_ref", +"nurbs_surface_order_body","nurbs_surface_uknots_body","nurbs_surface_vknots_body", +"nurbs_surface_trim_body","nurbs_surface_trim_loop_body","nurbs_curve_order_body", +"nurbs_curve_knots_body","table","@19","bundle","@20","table_body","sanim","@21", +"sanim_body","xfmanim","@22","xfmanim_body","xfm_s_anim","@23","xfm_s_anim_body", +"anim_preload","@24","anim_preload_body","integer_list","real_list","texture_name", +"material_name","vertex_pool_name","required_name","optional_name","required_string", +"optional_string","string","repeated_string","repeated_string_body","real","real_or_string", +"integer","empty", NULL +}; +#endif + +static const short yyr1[] = { 0, + 94, 94, 94, 94, 95, 95, 96, 96, 96, 96, + 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, + 96, 96, 96, 96, 97, 98, 100, 99, 101, 101, + 101, 103, 102, 104, 104, 105, 105, 107, 106, 108, + 108, 110, 109, 111, 109, 112, 112, 112, 112, 113, + 112, 112, 112, 112, 112, 114, 114, 114, 114, 114, + 114, 114, 114, 115, 115, 115, 116, 116, 116, 118, + 117, 120, 119, 122, 121, 123, 123, 123, 123, 123, + 123, 123, 123, 123, 123, 123, 123, 123, 123, 123, + 123, 123, 123, 124, 125, 125, 127, 126, 128, 128, + 128, 128, 128, 128, 128, 128, 128, 128, 128, 128, + 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, + 138, 139, 140, 140, 141, 142, 142, 143, 144, 144, + 145, 146, 146, 148, 147, 150, 149, 152, 151, 154, + 153, 156, 155, 158, 157, 160, 159, 161, 161, 161, + 162, 163, 162, 162, 162, 162, 162, 162, 162, 162, + 162, 164, 164, 164, 164, 164, 164, 164, 164, 164, + 164, 164, 164, 164, 164, 165, 165, 165, 165, 165, + 165, 165, 165, 165, 165, 165, 166, 167, 168, 169, + 169, 169, 170, 170, 170, 171, 172, 173, 174, 175, + 176, 176, 177, 177, 178, 179, 181, 180, 183, 182, + 184, 184, 184, 184, 184, 184, 186, 185, 187, 187, + 187, 189, 188, 190, 190, 190, 192, 191, 193, 193, + 193, 195, 194, 196, 196, 197, 197, 198, 198, 199, + 200, 201, 202, 202, 203, 204, 204, 205, 205, 206, + 206, 206, 207, 207, 208, 208, 209, 209, 210, 210, + 210, 211, 211, 212 +}; + +static const short yyr2[] = { 0, + 2, 2, 2, 2, 1, 2, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 4, 5, 0, 7, 1, 6, + 2, 0, 6, 1, 6, 5, 6, 0, 6, 1, + 2, 0, 5, 0, 6, 1, 2, 3, 4, 0, + 7, 5, 5, 8, 8, 2, 3, 7, 7, 7, + 8, 7, 8, 3, 8, 8, 4, 9, 9, 0, + 6, 0, 6, 0, 6, 1, 6, 5, 7, 7, + 5, 5, 5, 5, 5, 5, 5, 6, 5, 2, + 2, 2, 2, 1, 1, 2, 0, 5, 1, 2, + 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, + 2, 5, 6, 4, 4, 4, 4, 7, 5, 6, + 4, 4, 1, 9, 4, 1, 16, 9, 1, 6, + 4, 11, 12, 0, 6, 0, 6, 0, 6, 0, + 6, 0, 6, 0, 6, 0, 6, 1, 5, 5, + 1, 0, 7, 5, 5, 5, 2, 5, 5, 5, + 6, 1, 5, 5, 5, 2, 5, 5, 5, 5, + 5, 5, 2, 5, 6, 1, 5, 5, 5, 2, + 5, 5, 5, 5, 5, 6, 1, 1, 1, 3, + 8, 8, 4, 9, 9, 1, 8, 2, 1, 1, + 1, 5, 1, 2, 1, 1, 0, 6, 0, 6, + 1, 2, 2, 2, 2, 2, 0, 6, 1, 6, + 5, 0, 6, 1, 6, 5, 0, 6, 1, 6, + 2, 0, 6, 1, 6, 1, 2, 1, 2, 1, + 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, + 1, 1, 1, 1, 1, 2, 1, 1, 1, 1, + 1, 1, 1, 0 +}; + +static const short yydefact[] = { 0, + 264, 264, 264, 264, 1, 5, 2, 76, 3, 29, + 4, 151, 250, 251, 252, 264, 264, 0, 264, 264, + 264, 264, 264, 264, 264, 264, 264, 264, 264, 264, + 264, 264, 264, 6, 7, 8, 9, 10, 11, 12, + 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, + 23, 24, 0, 0, 0, 264, 0, 0, 0, 0, + 264, 0, 0, 264, 0, 97, 0, 93, 90, 91, + 92, 264, 31, 0, 0, 0, 0, 0, 264, 0, + 0, 0, 157, 232, 245, 249, 248, 0, 264, 0, + 70, 72, 74, 142, 0, 244, 243, 146, 144, 140, + 134, 207, 0, 136, 138, 38, 264, 0, 0, 0, + 0, 0, 0, 264, 0, 0, 0, 0, 0, 0, + 264, 0, 0, 262, 263, 0, 264, 0, 0, 0, + 264, 264, 264, 0, 264, 0, 247, 246, 264, 0, + 0, 0, 0, 32, 0, 0, 0, 0, 0, 264, + 0, 0, 0, 0, 0, 257, 258, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 264, + 0, 264, 264, 236, 0, 0, 196, 152, 0, 189, + 241, 0, 0, 0, 0, 0, 0, 188, 0, 187, + 240, 0, 264, 255, 0, 254, 253, 25, 0, 264, + 264, 264, 264, 264, 264, 264, 264, 264, 264, 27, + 264, 264, 264, 264, 78, 0, 264, 94, 84, 83, + 82, 81, 87, 86, 259, 260, 261, 0, 85, 0, + 131, 0, 89, 0, 99, 0, 237, 129, 0, 160, + 264, 156, 0, 158, 0, 0, 159, 0, 0, 155, + 154, 0, 0, 234, 26, 256, 36, 0, 0, 0, + 0, 0, 34, 0, 176, 0, 162, 0, 0, 0, + 211, 264, 0, 0, 0, 40, 0, 0, 0, 95, + 77, 0, 88, 0, 0, 0, 0, 0, 0, 0, + 0, 98, 100, 101, 102, 103, 104, 105, 106, 107, + 108, 109, 110, 111, 0, 264, 30, 0, 148, 0, + 0, 190, 0, 0, 0, 161, 264, 264, 233, 71, + 73, 75, 143, 264, 33, 0, 0, 0, 0, 0, + 0, 264, 0, 0, 147, 180, 0, 0, 0, 0, + 0, 264, 0, 0, 0, 0, 0, 145, 173, 166, + 141, 135, 264, 264, 264, 264, 208, 212, 213, 214, + 215, 216, 0, 137, 139, 42, 39, 41, 37, 79, + 80, 96, 0, 264, 264, 0, 0, 0, 0, 0, + 0, 264, 0, 0, 0, 153, 0, 0, 0, 0, + 193, 0, 242, 0, 0, 0, 264, 264, 0, 0, + 0, 0, 264, 264, 0, 264, 0, 0, 0, 0, + 264, 264, 264, 264, 264, 209, 217, 222, 227, 28, + 0, 44, 0, 0, 0, 0, 123, 0, 0, 126, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 206, + 238, 0, 0, 0, 205, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 201, + 0, 199, 0, 200, 0, 0, 0, 0, 0, 0, + 0, 0, 122, 0, 125, 0, 114, 0, 115, 116, + 117, 121, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 197, 0, 0, 183, 185, 239, 179, 181, + 184, 182, 0, 178, 177, 169, 165, 167, 170, 198, + 168, 0, 164, 163, 0, 174, 171, 172, 264, 264, + 264, 264, 0, 46, 0, 0, 0, 0, 0, 0, + 119, 0, 112, 0, 128, 130, 149, 150, 0, 0, + 0, 0, 235, 35, 186, 175, 264, 0, 0, 219, + 0, 224, 0, 229, 0, 0, 0, 264, 43, 47, + 0, 0, 0, 0, 0, 0, 120, 113, 192, 191, + 0, 0, 0, 203, 210, 264, 0, 218, 264, 0, + 223, 264, 228, 231, 0, 0, 0, 0, 0, 48, + 45, 0, 0, 0, 0, 118, 195, 194, 202, 204, + 0, 264, 0, 264, 0, 0, 0, 0, 0, 0, + 0, 50, 49, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 52, 0, 0, 53, 0, + 0, 132, 0, 0, 0, 0, 221, 0, 226, 0, + 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, + 133, 0, 0, 220, 225, 230, 0, 0, 0, 0, + 0, 0, 67, 0, 0, 0, 51, 56, 124, 0, + 55, 54, 0, 0, 0, 0, 0, 0, 0, 0, + 57, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 66, 65, 0, 0, 0, 0, 0, 0, 0, 69, + 68, 59, 62, 0, 60, 0, 58, 0, 63, 61, + 0, 127, 0, 0, 0 +}; + +static const short yydefgoto[] = { 733, + 5, 68, 35, 36, 37, 272, 9, 38, 204, 262, + 39, 40, 153, 275, 368, 421, 480, 533, 641, 659, + 618, 620, 41, 140, 42, 141, 43, 142, 7, 217, + 279, 69, 120, 234, 293, 294, 295, 296, 297, 298, + 299, 300, 301, 302, 303, 425, 304, 428, 70, 236, + 71, 169, 44, 148, 45, 151, 46, 152, 47, 147, + 48, 143, 49, 146, 50, 145, 308, 11, 241, 266, + 264, 189, 187, 179, 182, 184, 176, 83, 463, 471, + 473, 469, 583, 454, 449, 51, 149, 359, 475, 270, + 360, 476, 559, 361, 477, 561, 362, 478, 563, 52, + 134, 253, 173, 450, 190, 180, 392, 181, 84, 136, + 85, 96, 195, 196, 508, 228, 177, 97 +}; + +static const short yypact[] = { 211, +-32768,-32768,-32768,-32768, 1247,-32768, 1172,-32768, 105,-32768, + 337,-32768,-32768,-32768,-32768, 247, 247, -79, 247, 247, + 247, 247, 247, 247, 247, 247, 247, 247, 247, 247, + 247, 247, 247,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, 93, -60, -30, 247, 61, 70, 88, 92, + 247, 130, 147, 247, 150,-32768, 173,-32768,-32768,-32768, +-32768, 247,-32768, 175, 241, 177, 179, 181, 247, 183, + 189, 204,-32768,-32768,-32768,-32768,-32768, 205, 247, 214, +-32768,-32768,-32768,-32768, 215,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, 219,-32768,-32768,-32768, 247, 247, 283, 224, + 286, 333, 241, 247, 225, 241, 149, 227, 241, 235, +-32768, 236, 241,-32768,-32768, 239, 247, 283, 283, 242, + 247, 247,-32768, 254, 247, 166,-32768,-32768, 247, 255, + 262, 269, 270,-32768, 271, 272, 273, 274, 277, 247, + 284, 285, 287, 291, 221,-32768,-32768, 283, 247, 240, + 249, 282, 292, 293, 294, 336, 295, 297, 298, 247, + 300,-32768, 241,-32768, 336, 301,-32768,-32768, 302,-32768, +-32768, 34, 283, -11, 283, 336, 304,-32768, 305,-32768, +-32768, 136,-32768,-32768, 306, 247,-32768,-32768, 307,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768, 247,-32768, 283,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768, 309,-32768, 283, +-32768, 310,-32768, 222,-32768, 145,-32768,-32768, 311,-32768, +-32768,-32768, 84,-32768, 283, 87,-32768, 283, 312,-32768, +-32768, 314, 67,-32768,-32768,-32768,-32768, 792, 974, 1060, + 393, 99,-32768, 250,-32768, 187,-32768, 415, 479, 120, +-32768,-32768, 863, 1078, 144,-32768, 317, 319, 4,-32768, +-32768, 283,-32768, 332, 334, 341, 342, 343, 346, 348, + 350,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768, 351, 247,-32768, 190,-32768, 247, + 352,-32768, 247, 353, 283,-32768, 247, 247,-32768,-32768, +-32768,-32768,-32768, 247,-32768, 356, 358, 359, 363, 364, + 365, 247, 368, 372,-32768,-32768, 373, 378, 380, 381, + 385, 247, 396, 398, 399, 400, 401,-32768,-32768,-32768, +-32768,-32768, 247, 247, 247, 247,-32768,-32768,-32768,-32768, +-32768,-32768, 74,-32768,-32768, 241,-32768,-32768,-32768,-32768, +-32768,-32768, 104, 283, 283, 283, 283, 283, 283, 283, + 283, 247, 405, 407, 409,-32768, 283, 283, 283, 283, +-32768, 410,-32768, 412, 413, 241,-32768, 247, 283, 241, + 283, 414, 247, 247, 241, 247, 283, 241, 283, 417, + 247, 247,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, + 418,-32768, 419, 296, 420, 283,-32768, 421, 283,-32768, + 25, 422, 423, 424, 27, 283, 425, 336, 283, 283, + 283, 283, 283, 283, 427, 336, 336, 432, 434, 283, +-32768, 436, 38, 437,-32768, 26, 336, 438, 442, 443, + 444, 55, 450, 241, 80, 336, 451, 452, 77,-32768, + 453, 283, 454, 283, 456, 458, 459, 460, 283, 462, + 283, 463,-32768, 283,-32768, 283,-32768, 283,-32768,-32768, +-32768,-32768, 62, 64, 464, 465, 58, 107, 283, 283, + 283, 283,-32768, 466, 468,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, 469,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768, 472,-32768,-32768, 474,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, 119, 283, 283, 283, 283, 283, 283, 283, +-32768, 475,-32768, 476,-32768,-32768,-32768,-32768, 477, 478, + 283, 283,-32768,-32768,-32768,-32768,-32768, 131, 57,-32768, + 78,-32768, 156,-32768, 91, 481, 489, 247,-32768, 283, + 167, 283, 283, 283, 283, 490,-32768,-32768,-32768,-32768, + 491, 493, 48,-32768,-32768, 247, 495,-32768, 247, 496, +-32768, 247,-32768,-32768, 247, 497, 283, 283, 501, 283, +-32768, 502, 283, 283, 283,-32768,-32768,-32768,-32768,-32768, + 504,-32768, 505,-32768, 506, 283, 283, 59, 283, 117, + 283,-32768,-32768, 507, 508, 283, 283, 336, 66, 336, + 68, 336, 283, 283, 95,-32768, 283, 101,-32768, 283, + 283,-32768, 509, 283, 283, 510,-32768, 511,-32768, 512, + 283, 283, 247, 514,-32768, 247, 515, 283, 42, 283, +-32768, 283, 283,-32768,-32768,-32768, 516, 518, 283, 283, + 283, 283,-32768, 524, 109, 525,-32768, 283,-32768, 283, +-32768,-32768, 283, 283, 283, 283, 283, 247, 526, 283, +-32768, 283, 283, 283, 283, 283, 283, 283, 283, 283, + 283, 527, 528, 283, 283, 283, 283, 283, 283, 283, +-32768,-32768, 529, 530, 531, 73, 82, 532, 283,-32768, +-32768,-32768,-32768, 533,-32768, 534,-32768, 283,-32768,-32768, + 283,-32768, 384, 556,-32768 +}; + +static const short yypgoto[] = {-32768, +-32768, 562,-32768,-32768,-32768,-32768, 153,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768, -33,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 158,-32768, +-32768, -6,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768,-32768,-32768, -265,-32768,-32768, 118,-32768,-32768, +-32768, -185, -182, -170, -191, -207, -249, -231,-32768,-32768, +-32768,-32768,-32768,-32768,-32768, -266,-32768,-32768,-32768, -22, + -51,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, +-32768,-32768, 449, -409,-32768,-32768, 212, 50, 17, -89, +-32768, -5, 429,-32768, 40, -134, -56, 759 +}; + + +#define YYLAST 1373 + + +static const short yytable[] = { 53, + 349, 53, 73, 358, 472, 474, 13, 14, 15, 246, + 86, 86, 89, 86, 86, 86, 86, 86, 126, 86, + 86, 86, 86, 86, 165, 86, 86, 156, 157, 156, + 157, 108, 336, 88, 350, 90, 91, 92, 93, 94, + 239, 98, 99, 100, 101, 102, 246, 104, 105, 199, + 86, 249, 674, 243, 161, 163, 164, 243, 86, 167, + 210, 109, 171, 675, 156, 157, 156, 157, 156, 157, + 156, 157, 110, 95, 243, 156, 157, 243, 635, 103, + 118, 247, 106, 137, 156, 157, 13, 14, 15, 13, + 14, 15, 25, 13, 14, 15, 371, 13, 14, 15, + 246, 86, 155, 13, 14, 15, 156, 157, 137, 676, + 115, 13, 14, 15, 525, 586, 237, 487, 512, 492, + 107, 122, 587, 154, 277, 318, 244, 246, 130, 194, + 510, 353, 72, 137, 677, 237, 589, 638, 124, 125, + 609, 565, 353, 590, 137, 66, 448, 518, 158, 588, + 547, 636, 111, 218, 541, 460, 543, 324, 647, 319, + 649, 112, 566, 72, 194, 723, 420, 183, 185, 526, + 591, 567, 521, 168, 725, 310, 66, 354, 313, 113, + 188, 191, 595, 114, 29, 423, 653, 252, 354, 565, + 256, 325, 656, 456, 337, 29, 305, 216, 568, 548, + 688, 465, 629, 306, 631, 355, 356, 453, 137, 639, + 566, 569, 357, 354, 592, 462, 355, 356, 459, 567, + 458, 116, 245, 585, 248, 366, 468, 452, 467, 338, + 339, 25, 498, 384, 340, 461, 367, 311, 117, 341, + 314, 119, 385, 124, 125, 342, 568, 497, 593, 13, + 14, 15, 53, 53, 53, 278, 343, 326, 198, 601, + 344, 284, 285, 345, 121, 346, 123, 347, 127, 282, + 128, 82, 129, 372, 131, 286, 287, 288, 289, 348, + 132, 290, 386, 327, 312, 156, 157, 315, 124, 125, + 160, 358, 328, 329, 291, 133, 135, 330, 1, 2, + 3, 4, 331, 496, 387, 139, 144, 389, 332, 422, + 150, 504, 505, 215, 292, 159, 166, 610, 170, 333, + 261, 373, 513, 334, 268, 269, 172, 175, 273, 274, + 178, 522, 219, 186, 82, 124, 125, 162, 225, 226, + 227, 220, 335, 455, 74, 193, 200, 86, 86, 86, + 86, 464, 75, 201, 391, 383, 73, 258, 259, 260, + 202, 203, 205, 206, 207, 208, 393, 394, 209, 416, + 417, 418, 419, 395, 221, 211, 212, 482, 213, 76, + 77, 402, 214, 734, 222, 223, 224, 229, 230, 78, + 231, 410, 233, 240, 242, 79, 250, 251, 255, 257, + 74, 281, 283, 307, 316, 317, 80, 520, 75, 369, + 81, 370, 424, 426, 429, 431, 432, 433, 434, 435, + 436, 82, 74, 374, 363, 375, 441, 442, 443, 444, + 75, 393, 376, 377, 378, 76, 77, 379, 183, 380, + 185, 381, 382, 388, 390, 78, 183, 396, 185, 397, + 398, 79, 188, 191, 399, 400, 401, 76, 77, 403, + 188, 191, 80, 404, 405, 484, 81, 78, 486, 406, + 488, 407, 408, 79, 493, 494, 409, 82, 183, 185, + 499, 500, 501, 502, 80, 323, 74, 411, 81, 412, + 413, 414, 415, 646, 75, 648, 438, 650, 439, 82, + 440, 571, 445, 446, 447, 457, 558, 351, 466, 479, + 481, 594, 483, 485, 489, 490, 491, 495, 534, 503, + 536, 76, 77, 538, 506, 539, 507, 540, 509, 511, + 514, 78, 542, 544, 515, 516, 517, 79, 549, 550, + 551, 552, 519, 523, 524, 527, 528, 529, 80, 530, + 531, 532, 81, 535, 537, 735, 545, 546, 553, 596, + 554, 555, 86, 82, 556, 557, 34, 577, 578, 579, + 580, 352, 597, 570, 534, 572, 573, 574, 575, 576, + 598, 192, 606, 607, 599, 608, 612, 614, 617, 616, + 581, 582, 622, 437, 624, 628, 630, 632, 232, 642, + 643, 661, 664, 665, 666, 670, 672, 0, 681, 600, + 682, 602, 603, 604, 605, 687, 690, 699, 0, 711, + 712, 720, 721, 722, 727, 729, 730, 0, 0, 654, + 0, 0, 657, 0, 0, 611, 619, 621, 613, 623, + 0, 615, 625, 626, 627, 0, 0, 669, 0, 0, + 671, 0, 0, 0, 0, 633, 634, 0, 637, 0, + 640, 0, 0, 0, 0, 644, 645, 0, 0, 689, + 0, 0, 651, 652, 0, 0, 655, 0, 0, 658, + 660, 0, 698, 662, 663, 0, 0, 0, 0, 0, + 667, 668, 0, 0, 0, 0, 0, 673, 0, 678, + 0, 679, 680, 0, 0, 0, 0, 0, 683, 684, + 685, 686, 0, 0, 0, 0, 0, 691, 0, 692, + 0, 0, 693, 694, 695, 696, 697, 0, 0, 700, + 0, 701, 702, 703, 704, 705, 706, 707, 708, 709, + 710, 0, 0, 713, 714, 715, 716, 717, 718, 719, + 0, 0, 0, 0, 0, 724, 726, 0, 728, 6, + 8, 10, 12, 0, 0, 0, 0, 731, 0, 0, + 732, 0, 0, 0, 87, 87, 0, 87, 87, 87, + 87, 87, 0, 87, 87, 87, 87, 87, 0, 87, + 87, 0, 0, 0, 13, 14, 15, 16, 0, 0, + 54, 55, 0, 0, 0, 56, 17, 0, 18, 0, + 57, 0, 0, 0, 87, 58, 0, 0, 0, 19, + 0, 20, 87, 0, 21, 0, 0, 22, 23, 0, + 24, 0, 0, 59, 0, 0, 25, 26, 60, 0, + 0, 27, 28, 0, 0, 0, 0, 138, 0, 0, + 61, 0, 0, 0, 62, 63, 29, 0, 64, 0, + 65, 30, 0, 66, 0, 87, 31, 32, 0, 0, + 74, 0, 138, 0, 0, 33, 67, 0, 75, 174, + 0, 0, 0, 0, 320, 0, 0, 0, 0, 0, + 0, 174, 0, 197, 0, 0, 0, 138, 0, 0, + 0, 0, 0, 0, 0, 76, 77, 0, 138, 0, + 0, 0, 0, 0, 0, 78, 0, 0, 0, 0, + 0, 79, 0, 0, 0, 0, 0, 0, 197, 0, + 235, 238, 80, 0, 0, 0, 81, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 82, 0, 0, + 0, 254, 0, 0, 0, 364, 0, 0, 8, 8, + 8, 12, 263, 265, 267, 12, 12, 271, 0, 12, + 12, 276, 138, 0, 0, 280, 13, 14, 15, 16, + 0, 0, 54, 55, 0, 0, 0, 56, 17, 0, + 18, 0, 57, 0, 0, 0, 0, 58, 0, 309, + 0, 19, 0, 20, 0, 0, 21, 0, 0, 22, + 23, 0, 24, 0, 0, 59, 0, 0, 25, 26, + 60, 0, 0, 27, 28, 0, 0, 0, 0, 0, + 10, 0, 61, 0, 0, 0, 62, 63, 29, 0, + 64, 0, 65, 30, 0, 66, 0, 0, 31, 32, + 0, 0, 0, 0, 0, 0, 0, 33, 67, 0, + 0, 0, 13, 14, 15, 16, 321, 0, 54, 55, + 0, 0, 0, 56, 17, 0, 18, 0, 57, 0, + 0, 0, 0, 58, 0, 74, 0, 19, 0, 20, + 0, 0, 21, 75, 0, 22, 23, 0, 24, 0, + 0, 59, 0, 0, 25, 26, 60, 0, 0, 27, + 28, 87, 87, 87, 87, 0, 0, 0, 61, 0, + 76, 77, 62, 63, 29, 0, 64, 0, 65, 30, + 78, 66, 427, 430, 31, 32, 79, 0, 0, 0, + 0, 0, 0, 33, 67, 0, 0, 80, 0, 0, + 0, 81, 322, 0, 0, 451, 0, 0, 0, 0, + 0, 0, 82, 0, 0, 0, 0, 0, 0, 0, + 365, 470, 451, 451, 13, 14, 15, 16, 0, 0, + 54, 55, 0, 0, 0, 56, 17, 0, 18, 0, + 57, 0, 0, 0, 0, 58, 0, 0, 0, 19, + 0, 20, 0, 0, 21, 0, 0, 22, 23, 0, + 24, 0, 0, 59, 0, 0, 25, 26, 60, 0, + 0, 27, 28, 0, 0, 0, 0, 0, 0, 0, + 61, 0, 0, 0, 62, 63, 29, 0, 64, 0, + 65, 30, 0, 66, 0, 0, 31, 32, 0, 13, + 14, 15, 16, 0, 0, 33, 67, 0, 0, 0, + 0, 17, 0, 18, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 19, 0, 20, 0, 0, 21, + 0, 0, 22, 23, 0, 24, 0, 271, 560, 562, + 564, 25, 26, 0, 0, 0, 27, 28, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 29, 0, 0, 0, 584, 30, 0, 0, 0, + 0, 31, 32, 0, 0, 0, 87, 0, 0, 0, + 33, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 451, 0, 451 +}; + +static const short yycheck[] = { 5, + 266, 7, 9, 270, 414, 415, 3, 4, 5, 21, + 16, 17, 92, 19, 20, 21, 22, 23, 75, 25, + 26, 27, 28, 29, 114, 31, 32, 3, 4, 3, + 4, 92, 264, 17, 266, 19, 20, 21, 22, 23, + 175, 25, 26, 27, 28, 29, 21, 31, 32, 139, + 56, 186, 11, 20, 111, 112, 113, 20, 64, 116, + 150, 92, 119, 22, 3, 4, 3, 4, 3, 4, + 3, 4, 56, 24, 20, 3, 4, 20, 20, 30, + 64, 93, 33, 89, 3, 4, 3, 4, 5, 3, + 4, 5, 45, 3, 4, 5, 93, 3, 4, 5, + 21, 107, 108, 3, 4, 5, 3, 4, 114, 68, + 61, 3, 4, 5, 38, 59, 173, 93, 93, 93, + 28, 72, 66, 107, 214, 59, 93, 21, 79, 135, + 93, 12, 59, 139, 93, 192, 59, 21, 3, 4, + 93, 23, 12, 66, 150, 72, 396, 93, 109, 93, + 93, 93, 92, 159, 93, 405, 93, 59, 93, 93, + 93, 92, 44, 59, 170, 93, 93, 128, 129, 93, + 93, 53, 93, 25, 93, 92, 72, 58, 92, 92, + 131, 132, 92, 92, 65, 82, 92, 52, 58, 23, + 196, 93, 92, 401, 8, 65, 52, 158, 80, 93, + 92, 409, 612, 59, 614, 86, 87, 399, 214, 93, + 44, 93, 93, 58, 59, 407, 86, 87, 404, 53, + 403, 92, 183, 93, 185, 82, 412, 398, 411, 43, + 44, 45, 440, 44, 48, 406, 93, 243, 92, 53, + 246, 92, 53, 3, 4, 59, 80, 439, 93, 3, + 4, 5, 258, 259, 260, 216, 70, 8, 93, 93, + 74, 40, 41, 77, 92, 79, 92, 81, 92, 230, + 92, 85, 92, 279, 92, 54, 55, 56, 57, 93, + 92, 60, 93, 34, 245, 3, 4, 248, 3, 4, + 5, 558, 43, 44, 73, 92, 92, 48, 88, 89, + 90, 91, 53, 438, 310, 92, 92, 313, 59, 366, + 92, 446, 447, 93, 93, 92, 92, 583, 92, 70, + 203, 282, 457, 74, 207, 208, 92, 92, 211, 212, + 92, 466, 93, 92, 85, 3, 4, 5, 3, 4, + 5, 93, 93, 400, 8, 92, 92, 353, 354, 355, + 356, 408, 16, 92, 315, 306, 363, 200, 201, 202, + 92, 92, 92, 92, 92, 92, 317, 318, 92, 353, + 354, 355, 356, 324, 93, 92, 92, 82, 92, 43, + 44, 332, 92, 0, 93, 93, 93, 93, 92, 53, + 93, 342, 93, 93, 93, 59, 93, 93, 93, 93, + 8, 93, 93, 93, 93, 92, 70, 464, 16, 93, + 74, 93, 373, 374, 375, 376, 377, 378, 379, 380, + 381, 85, 8, 92, 272, 92, 387, 388, 389, 390, + 16, 382, 92, 92, 92, 43, 44, 92, 399, 92, + 401, 92, 92, 92, 92, 53, 407, 92, 409, 92, + 92, 59, 403, 404, 92, 92, 92, 43, 44, 92, + 411, 412, 70, 92, 92, 426, 74, 53, 429, 92, + 431, 92, 92, 59, 435, 436, 92, 85, 439, 440, + 441, 442, 443, 444, 70, 93, 8, 92, 74, 92, + 92, 92, 92, 628, 16, 630, 92, 632, 92, 85, + 92, 535, 93, 92, 92, 92, 529, 93, 92, 92, + 92, 563, 93, 93, 93, 93, 93, 93, 479, 93, + 481, 43, 44, 484, 93, 486, 93, 488, 93, 93, + 93, 53, 493, 494, 93, 93, 93, 59, 499, 500, + 501, 502, 93, 93, 93, 93, 93, 92, 70, 92, + 92, 92, 74, 92, 92, 0, 93, 93, 93, 565, + 93, 93, 568, 85, 93, 92, 5, 93, 93, 93, + 93, 93, 92, 534, 535, 536, 537, 538, 539, 540, + 92, 133, 93, 93, 568, 93, 92, 92, 92, 595, + 551, 552, 92, 382, 93, 92, 92, 92, 170, 93, + 93, 93, 93, 93, 93, 92, 92, -1, 93, 570, + 93, 572, 573, 574, 575, 92, 92, 92, -1, 93, + 93, 93, 93, 93, 93, 93, 93, -1, -1, 635, + -1, -1, 638, -1, -1, 586, 597, 598, 589, 600, + -1, 592, 603, 604, 605, -1, -1, 653, -1, -1, + 656, -1, -1, -1, -1, 616, 617, -1, 619, -1, + 621, -1, -1, -1, -1, 626, 627, -1, -1, 675, + -1, -1, 633, 634, -1, -1, 637, -1, -1, 640, + 641, -1, 688, 644, 645, -1, -1, -1, -1, -1, + 651, 652, -1, -1, -1, -1, -1, 658, -1, 660, + -1, 662, 663, -1, -1, -1, -1, -1, 669, 670, + 671, 672, -1, -1, -1, -1, -1, 678, -1, 680, + -1, -1, 683, 684, 685, 686, 687, -1, -1, 690, + -1, 692, 693, 694, 695, 696, 697, 698, 699, 700, + 701, -1, -1, 704, 705, 706, 707, 708, 709, 710, + -1, -1, -1, -1, -1, 716, 717, -1, 719, 1, + 2, 3, 4, -1, -1, -1, -1, 728, -1, -1, + 731, -1, -1, -1, 16, 17, -1, 19, 20, 21, + 22, 23, -1, 25, 26, 27, 28, 29, -1, 31, + 32, -1, -1, -1, 3, 4, 5, 6, -1, -1, + 9, 10, -1, -1, -1, 14, 15, -1, 17, -1, + 19, -1, -1, -1, 56, 24, -1, -1, -1, 28, + -1, 30, 64, -1, 33, -1, -1, 36, 37, -1, + 39, -1, -1, 42, -1, -1, 45, 46, 47, -1, + -1, 50, 51, -1, -1, -1, -1, 89, -1, -1, + 59, -1, -1, -1, 63, 64, 65, -1, 67, -1, + 69, 70, -1, 72, -1, 107, 75, 76, -1, -1, + 8, -1, 114, -1, -1, 84, 85, -1, 16, 121, + -1, -1, -1, -1, 93, -1, -1, -1, -1, -1, + -1, 133, -1, 135, -1, -1, -1, 139, -1, -1, + -1, -1, -1, -1, -1, 43, 44, -1, 150, -1, + -1, -1, -1, -1, -1, 53, -1, -1, -1, -1, + -1, 59, -1, -1, -1, -1, -1, -1, 170, -1, + 172, 173, 70, -1, -1, -1, 74, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, 85, -1, -1, + -1, 193, -1, -1, -1, 93, -1, -1, 200, 201, + 202, 203, 204, 205, 206, 207, 208, 209, -1, 211, + 212, 213, 214, -1, -1, 217, 3, 4, 5, 6, + -1, -1, 9, 10, -1, -1, -1, 14, 15, -1, + 17, -1, 19, -1, -1, -1, -1, 24, -1, 241, + -1, 28, -1, 30, -1, -1, 33, -1, -1, 36, + 37, -1, 39, -1, -1, 42, -1, -1, 45, 46, + 47, -1, -1, 50, 51, -1, -1, -1, -1, -1, + 272, -1, 59, -1, -1, -1, 63, 64, 65, -1, + 67, -1, 69, 70, -1, 72, -1, -1, 75, 76, + -1, -1, -1, -1, -1, -1, -1, 84, 85, -1, + -1, -1, 3, 4, 5, 6, 93, -1, 9, 10, + -1, -1, -1, 14, 15, -1, 17, -1, 19, -1, + -1, -1, -1, 24, -1, 8, -1, 28, -1, 30, + -1, -1, 33, 16, -1, 36, 37, -1, 39, -1, + -1, 42, -1, -1, 45, 46, 47, -1, -1, 50, + 51, 353, 354, 355, 356, -1, -1, -1, 59, -1, + 43, 44, 63, 64, 65, -1, 67, -1, 69, 70, + 53, 72, 374, 375, 75, 76, 59, -1, -1, -1, + -1, -1, -1, 84, 85, -1, -1, 70, -1, -1, + -1, 74, 93, -1, -1, 397, -1, -1, -1, -1, + -1, -1, 85, -1, -1, -1, -1, -1, -1, -1, + 93, 413, 414, 415, 3, 4, 5, 6, -1, -1, + 9, 10, -1, -1, -1, 14, 15, -1, 17, -1, + 19, -1, -1, -1, -1, 24, -1, -1, -1, 28, + -1, 30, -1, -1, 33, -1, -1, 36, 37, -1, + 39, -1, -1, 42, -1, -1, 45, 46, 47, -1, + -1, 50, 51, -1, -1, -1, -1, -1, -1, -1, + 59, -1, -1, -1, 63, 64, 65, -1, 67, -1, + 69, 70, -1, 72, -1, -1, 75, 76, -1, 3, + 4, 5, 6, -1, -1, 84, 85, -1, -1, -1, + -1, 15, -1, 17, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, 28, -1, 30, -1, -1, 33, + -1, -1, 36, 37, -1, 39, -1, 529, 530, 531, + 532, 45, 46, -1, -1, -1, 50, 51, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, 65, -1, -1, -1, 557, 70, -1, -1, -1, + -1, 75, 76, -1, -1, -1, 568, -1, -1, -1, + 84, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + 612, -1, 614 +}; +/* -*-C-*- Note some compilers choke on comments on `#line' lines. */ +#line 3 "/usr/share/bison.simple" +/* This file comes from bison-1.28. */ + +/* Skeleton output parser for bison, + Copyright (C) 1984, 1989, 1990 Free Software Foundation, Inc. + + 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., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. */ + +/* As a special exception, when this file is copied by Bison into a + Bison output file, you may use that output file without restriction. + This special exception was added by the Free Software Foundation + in version 1.24 of Bison. */ + +/* This is the parser code that is written into each bison parser + when the %semantic_parser declaration is not specified in the grammar. + It was written by Richard Stallman by simplifying the hairy parser + used when %semantic_parser is specified. */ + +#ifndef YYSTACK_USE_ALLOCA +#ifdef alloca +#define YYSTACK_USE_ALLOCA +#else /* alloca not defined */ +#ifdef __GNUC__ +#define YYSTACK_USE_ALLOCA +#define alloca __builtin_alloca +#else /* not GNU C. */ +#if (!defined (__STDC__) && defined (sparc)) || defined (__sparc__) || defined (__sparc) || defined (__sgi) || (defined (__sun) && defined (__i386)) +#define YYSTACK_USE_ALLOCA +#include +#else /* not sparc */ +/* We think this test detects Watcom and Microsoft C. */ +/* This used to test MSDOS, but that is a bad idea + since that symbol is in the user namespace. */ +#if (defined (_MSDOS) || defined (_MSDOS_)) && !defined (__TURBOC__) +#if 0 /* No need for malloc.h, which pollutes the namespace; + instead, just don't use alloca. */ +#include +#endif +#else /* not MSDOS, or __TURBOC__ */ +#if defined(_AIX) +/* I don't know what this was needed for, but it pollutes the namespace. + So I turned it off. rms, 2 May 1997. */ +/* #include */ + #pragma alloca +#define YYSTACK_USE_ALLOCA +#else /* not MSDOS, or __TURBOC__, or _AIX */ +#if 0 +#ifdef __hpux /* haible@ilog.fr says this works for HPUX 9.05 and up, + and on HPUX 10. Eventually we can turn this on. */ +#define YYSTACK_USE_ALLOCA +#define alloca __builtin_alloca +#endif /* __hpux */ +#endif +#endif /* not _AIX */ +#endif /* not MSDOS, or __TURBOC__ */ +#endif /* not sparc */ +#endif /* not GNU C */ +#endif /* alloca not defined */ +#endif /* YYSTACK_USE_ALLOCA not defined */ + +#ifdef YYSTACK_USE_ALLOCA +#define YYSTACK_ALLOC alloca #else -# define YYERROR_VERBOSE 0 +#define YYSTACK_ALLOC malloc #endif -/* Enabling the token table. */ -#ifndef YYTOKEN_TABLE -# define YYTOKEN_TABLE 0 -#endif - -#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED -typedef int YYSTYPE; -# define yystype YYSTYPE /* obsolescent; will be withdrawn */ -# define YYSTYPE_IS_DECLARED 1 -# define YYSTYPE_IS_TRIVIAL 1 -#endif - - - -/* Copy the second part of user declarations. */ - - -/* Line 216 of yacc.c. */ -#line 433 "y.tab.c" - -#ifdef short -# undef short -#endif - -#ifdef YYTYPE_UINT8 -typedef YYTYPE_UINT8 yytype_uint8; -#else -typedef unsigned char yytype_uint8; -#endif - -#ifdef YYTYPE_INT8 -typedef YYTYPE_INT8 yytype_int8; -#elif (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -typedef signed char yytype_int8; -#else -typedef short int yytype_int8; -#endif - -#ifdef YYTYPE_UINT16 -typedef YYTYPE_UINT16 yytype_uint16; -#else -typedef unsigned short int yytype_uint16; -#endif - -#ifdef YYTYPE_INT16 -typedef YYTYPE_INT16 yytype_int16; -#else -typedef short int yytype_int16; -#endif - -#ifndef YYSIZE_T -# ifdef __SIZE_TYPE__ -# define YYSIZE_T __SIZE_TYPE__ -# elif defined size_t -# define YYSIZE_T size_t -# elif ! defined YYSIZE_T && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -# include /* INFRINGES ON USER NAME SPACE */ -# define YYSIZE_T size_t -# else -# define YYSIZE_T unsigned int -# endif -#endif - -#define YYSIZE_MAXIMUM ((YYSIZE_T) -1) - -#ifndef YY_ -# if YYENABLE_NLS -# if ENABLE_NLS -# include /* INFRINGES ON USER NAME SPACE */ -# define YY_(msgid) dgettext ("bison-runtime", msgid) -# endif -# endif -# ifndef YY_ -# define YY_(msgid) msgid -# endif -#endif - -/* Suppress unused-variable warnings by "using" E. */ -#if ! defined lint || defined __GNUC__ -# define YYUSE(e) ((void) (e)) -#else -# define YYUSE(e) /* empty */ -#endif - -/* Identity function, used to suppress warnings about constant conditions. */ -#ifndef lint -# define YYID(n) (n) -#else -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static int -YYID (int i) -#else -static int -YYID (i) - int i; -#endif -{ - return i; -} -#endif - -#if ! defined yyoverflow || YYERROR_VERBOSE - -/* The parser invokes alloca or malloc; define the necessary symbols. */ - -# ifdef YYSTACK_USE_ALLOCA -# if YYSTACK_USE_ALLOCA -# ifdef __GNUC__ -# define YYSTACK_ALLOC __builtin_alloca -# elif defined __BUILTIN_VA_ARG_INCR -# include /* INFRINGES ON USER NAME SPACE */ -# elif defined _AIX -# define YYSTACK_ALLOC __alloca -# elif defined _MSC_VER -# include /* INFRINGES ON USER NAME SPACE */ -# define alloca _alloca -# else -# define YYSTACK_ALLOC alloca -# if ! defined _ALLOCA_H && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -# include /* INFRINGES ON USER NAME SPACE */ -# ifndef _STDLIB_H -# define _STDLIB_H 1 -# endif -# endif -# endif -# endif -# endif - -# ifdef YYSTACK_ALLOC - /* Pacify GCC's `empty if-body' warning. */ -# define YYSTACK_FREE(Ptr) do { /* empty */; } while (YYID (0)) -# ifndef YYSTACK_ALLOC_MAXIMUM - /* The OS might guarantee only one guard page at the bottom of the stack, - and a page size can be as small as 4096 bytes. So we cannot safely - invoke alloca (N) if N exceeds 4096. Use a slightly smaller number - to allow for a few compiler-allocated temporary stack slots. */ -# define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2006 */ -# endif -# else -# define YYSTACK_ALLOC YYMALLOC -# define YYSTACK_FREE YYFREE -# ifndef YYSTACK_ALLOC_MAXIMUM -# define YYSTACK_ALLOC_MAXIMUM YYSIZE_MAXIMUM -# endif -# if (defined __cplusplus && ! defined _STDLIB_H \ - && ! ((defined YYMALLOC || defined malloc) \ - && (defined YYFREE || defined free))) -# include /* INFRINGES ON USER NAME SPACE */ -# ifndef _STDLIB_H -# define _STDLIB_H 1 -# endif -# endif -# ifndef YYMALLOC -# define YYMALLOC malloc -# if ! defined malloc && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ -# endif -# endif -# ifndef YYFREE -# define YYFREE free -# if ! defined free && ! defined _STDLIB_H && (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -void free (void *); /* INFRINGES ON USER NAME SPACE */ -# endif -# endif -# endif -#endif /* ! defined yyoverflow || YYERROR_VERBOSE */ - - -#if (! defined yyoverflow \ - && (! defined __cplusplus \ - || (defined YYSTYPE_IS_TRIVIAL && YYSTYPE_IS_TRIVIAL))) - -/* A type that is properly aligned for any stack member. */ -union yyalloc -{ - yytype_int16 yyss; - YYSTYPE yyvs; - }; - -/* The size of the maximum gap between one aligned stack and the next. */ -# define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) - -/* The size of an array large to enough to hold all stacks, each with - N elements. */ -# define YYSTACK_BYTES(N) \ - ((N) * (sizeof (yytype_int16) + sizeof (YYSTYPE)) \ - + YYSTACK_GAP_MAXIMUM) - -/* Copy COUNT objects from FROM to TO. The source and destination do - not overlap. */ -# ifndef YYCOPY -# if defined __GNUC__ && 1 < __GNUC__ -# define YYCOPY(To, From, Count) \ - __builtin_memcpy (To, From, (Count) * sizeof (*(From))) -# else -# define YYCOPY(To, From, Count) \ - do \ - { \ - YYSIZE_T yyi; \ - for (yyi = 0; yyi < (Count); yyi++) \ - (To)[yyi] = (From)[yyi]; \ - } \ - while (YYID (0)) -# endif -# endif - -/* Relocate STACK from its old location to the new one. The - local variables YYSIZE and YYSTACKSIZE give the old and new number of - elements in the stack, and YYPTR gives the new location of the - stack. Advance YYPTR to a properly aligned location for the next - stack. */ -# define YYSTACK_RELOCATE(Stack) \ - do \ - { \ - YYSIZE_T yynewbytes; \ - YYCOPY (&yyptr->Stack, Stack, yysize); \ - Stack = &yyptr->Stack; \ - yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ - yyptr += yynewbytes / sizeof (*yyptr); \ - } \ - while (YYID (0)) - -#endif - -/* YYFINAL -- State number of the termination state. */ -#define YYFINAL 14 -/* YYLAST -- Last index in YYTABLE. */ -#define YYLAST 1343 - -/* YYNTOKENS -- Number of terminals. */ -#define YYNTOKENS 93 -/* YYNNTS -- Number of nonterminals. */ -#define YYNNTS 117 -/* YYNRULES -- Number of rules. */ -#define YYNRULES 260 -/* YYNRULES -- Number of states. */ -#define YYNSTATES 722 - -/* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX. */ -#define YYUNDEFTOK 2 -#define YYMAXUTOK 345 - -#define YYTRANSLATE(YYX) \ - ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK) - -/* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX. */ -static const yytype_uint8 yytranslate[] = -{ - 0, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 91, 2, 92, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 2, 2, 2, 2, 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, 39, 40, 41, 42, 43, 44, - 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, - 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, - 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, - 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, - 85, 86, 87, 88, 89, 90 -}; - -#if YYDEBUG -/* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in - YYRHS. */ -static const yytype_uint16 yyprhs[] = -{ - 0, 0, 3, 6, 9, 12, 15, 17, 20, 22, - 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, - 44, 46, 48, 50, 52, 54, 59, 65, 66, 74, - 76, 83, 86, 87, 94, 96, 103, 109, 116, 117, - 124, 126, 129, 130, 136, 137, 144, 146, 149, 153, - 158, 159, 167, 173, 179, 188, 197, 200, 204, 212, - 220, 228, 237, 245, 254, 258, 267, 276, 281, 291, - 301, 302, 309, 310, 317, 318, 325, 327, 334, 340, - 348, 356, 362, 368, 374, 380, 386, 392, 398, 405, - 411, 414, 417, 420, 423, 425, 427, 430, 431, 437, - 439, 442, 445, 448, 451, 454, 457, 460, 463, 466, - 469, 472, 475, 481, 488, 493, 498, 503, 508, 516, - 522, 529, 534, 539, 541, 551, 556, 558, 575, 585, - 587, 594, 599, 611, 624, 625, 632, 633, 640, 641, - 648, 649, 656, 657, 664, 665, 672, 673, 680, 682, - 688, 694, 696, 697, 705, 711, 717, 723, 726, 732, - 738, 744, 751, 753, 759, 765, 771, 774, 780, 786, - 792, 798, 804, 810, 813, 819, 826, 828, 834, 840, - 846, 849, 855, 861, 867, 873, 879, 886, 888, 890, - 892, 896, 905, 914, 919, 929, 939, 941, 950, 953, - 955, 957, 959, 965, 967, 970, 972, 974, 975, 982, - 983, 990, 992, 995, 998, 1001, 1004, 1007, 1008, 1015, - 1017, 1024, 1030, 1031, 1038, 1040, 1047, 1053, 1054, 1061, - 1063, 1070, 1073, 1075, 1078, 1080, 1083, 1085, 1087, 1089, - 1091, 1093, 1095, 1097, 1099, 1101, 1103, 1105, 1107, 1109, - 1111, 1113, 1115, 1118, 1120, 1122, 1124, 1126, 1128, 1130, - 1132 -}; - -/* YYRHS -- A `-1'-separated list of the rules' RHS. */ -static const yytype_int16 yyrhs[] = -{ - 94, 0, -1, 87, 95, -1, 88, 123, -1, 89, - 101, -1, 90, 162, -1, 209, -1, 95, 96, -1, - 97, -1, 98, -1, 99, -1, 102, -1, 105, -1, - 106, -1, 117, -1, 119, -1, 121, -1, 147, -1, - 149, -1, 151, -1, 153, -1, 155, -1, 157, -1, - 159, -1, 180, -1, 16, 91, 201, 92, -1, 14, - 200, 91, 204, 92, -1, -1, 69, 199, 91, 201, - 100, 101, 92, -1, 209, -1, 101, 58, 199, 91, - 207, 92, -1, 101, 126, -1, -1, 38, 199, 91, - 103, 104, 92, -1, 209, -1, 104, 58, 199, 91, - 207, 92, -1, 27, 200, 91, 201, 92, -1, 203, - 27, 200, 91, 201, 92, -1, -1, 83, 199, 107, - 91, 108, 92, -1, 209, -1, 108, 109, -1, -1, - 81, 110, 91, 112, 92, -1, -1, 81, 208, 111, - 91, 112, 92, -1, 206, -1, 206, 206, -1, 206, - 206, 206, -1, 206, 206, 206, 206, -1, -1, 112, - 79, 200, 91, 113, 114, 92, -1, 112, 43, 91, - 115, 92, -1, 112, 52, 91, 116, 92, -1, 112, - 22, 203, 91, 206, 206, 206, 92, -1, 112, 22, - 91, 203, 206, 206, 206, 92, -1, 206, 206, -1, - 206, 206, 206, -1, 114, 67, 91, 206, 206, 206, - 92, -1, 114, 10, 91, 206, 206, 206, 92, -1, - 114, 21, 203, 91, 206, 206, 92, -1, 114, 21, - 203, 91, 206, 206, 206, 92, -1, 114, 21, 91, - 203, 206, 206, 92, -1, 114, 21, 91, 203, 206, - 206, 206, 92, -1, 206, 206, 206, -1, 115, 19, - 203, 91, 206, 206, 206, 92, -1, 115, 19, 91, - 203, 206, 206, 206, 92, -1, 206, 206, 206, 206, - -1, 116, 20, 203, 91, 206, 206, 206, 206, 92, - -1, 116, 20, 91, 203, 206, 206, 206, 206, 92, - -1, -1, 29, 200, 118, 91, 123, 92, -1, -1, - 32, 200, 120, 91, 123, 92, -1, -1, 35, 200, - 122, 91, 123, 92, -1, 209, -1, 123, 58, 199, - 91, 207, 92, -1, 123, 8, 91, 203, 92, -1, - 123, 9, 91, 206, 206, 206, 92, -1, 123, 13, - 200, 91, 124, 125, 92, -1, 123, 23, 91, 208, - 92, -1, 123, 23, 91, 5, 92, -1, 123, 18, - 91, 208, 92, -1, 123, 18, 91, 5, 92, -1, - 123, 62, 91, 208, 92, -1, 123, 46, 91, 201, - 92, -1, 123, 41, 91, 208, 92, -1, 123, 66, - 200, 91, 204, 92, -1, 123, 68, 91, 208, 92, - -1, 123, 126, -1, 123, 143, -1, 123, 145, -1, - 123, 96, -1, 203, -1, 209, -1, 125, 203, -1, - -1, 71, 127, 91, 128, 92, -1, 209, -1, 128, - 129, -1, 128, 130, -1, 128, 131, -1, 128, 132, - -1, 128, 133, -1, 128, 134, -1, 128, 135, -1, - 128, 136, -1, 128, 137, -1, 128, 138, -1, 128, - 139, -1, 128, 141, -1, 72, 91, 206, 206, 92, - -1, 72, 91, 206, 206, 206, 92, -1, 53, 91, - 206, 92, -1, 54, 91, 206, 92, -1, 55, 91, - 206, 92, -1, 56, 91, 206, 92, -1, 53, 91, - 206, 206, 206, 206, 92, -1, 59, 91, 206, 206, - 92, -1, 59, 91, 206, 206, 206, 92, -1, 59, - 91, 206, 92, -1, 39, 91, 140, 92, -1, 209, - -1, 206, 206, 206, 206, 206, 206, 206, 206, 206, - -1, 40, 91, 142, 92, -1, 209, -1, 206, 206, - 206, 206, 206, 206, 206, 206, 206, 206, 206, 206, - 206, 206, 206, 206, -1, 84, 91, 194, 144, 51, - 91, 198, 92, 92, -1, 209, -1, 144, 58, 199, - 91, 207, 92, -1, 63, 91, 146, 92, -1, 24, - 91, 206, 206, 81, 91, 206, 206, 206, 92, 92, - -1, 24, 91, 206, 206, 206, 81, 91, 206, 206, - 206, 92, 92, -1, -1, 50, 200, 148, 91, 162, - 92, -1, -1, 74, 200, 150, 91, 162, 92, -1, - -1, 75, 200, 152, 91, 162, 92, -1, -1, 49, - 200, 154, 91, 162, 92, -1, -1, 36, 200, 156, - 91, 162, 92, -1, -1, 45, 200, 158, 91, 164, - 92, -1, -1, 44, 200, 160, 91, 165, 92, -1, - 209, -1, 161, 43, 91, 169, 92, -1, 161, 52, - 91, 170, 92, -1, 209, -1, -1, 162, 15, 208, - 91, 163, 161, 92, -1, 162, 73, 91, 166, 92, - -1, 162, 69, 91, 167, 92, -1, 162, 42, 91, - 168, 92, -1, 162, 172, -1, 162, 43, 91, 169, - 92, -1, 162, 52, 91, 170, 92, -1, 162, 7, - 91, 171, 92, -1, 162, 58, 199, 91, 207, 92, - -1, 209, -1, 164, 73, 91, 166, 92, -1, 164, - 69, 91, 167, 92, -1, 164, 42, 91, 168, 92, - -1, 164, 172, -1, 164, 43, 91, 169, 92, -1, - 164, 52, 91, 170, 92, -1, 164, 7, 91, 171, - 92, -1, 164, 47, 91, 173, 92, -1, 164, 78, - 91, 174, 92, -1, 164, 80, 91, 175, 92, -1, - 164, 159, -1, 164, 76, 91, 176, 92, -1, 164, - 58, 199, 91, 207, 92, -1, 209, -1, 165, 73, - 91, 166, 92, -1, 165, 69, 91, 167, 92, -1, - 165, 42, 91, 168, 92, -1, 165, 172, -1, 165, - 43, 91, 169, 92, -1, 165, 52, 91, 170, 92, - -1, 165, 7, 91, 171, 92, -1, 165, 47, 91, - 178, 92, -1, 165, 33, 91, 179, 92, -1, 165, - 58, 199, 91, 207, 92, -1, 196, -1, 199, -1, - 197, -1, 206, 206, 206, -1, 169, 19, 203, 91, - 206, 206, 206, 92, -1, 169, 19, 91, 203, 206, - 206, 206, 92, -1, 206, 206, 206, 206, -1, 170, - 20, 203, 91, 206, 206, 206, 206, 92, -1, 170, - 20, 91, 203, 206, 206, 206, 206, 92, -1, 208, - -1, 84, 91, 194, 51, 91, 198, 92, 92, -1, - 208, 208, -1, 195, -1, 195, -1, 209, -1, 176, - 37, 91, 177, 92, -1, 209, -1, 177, 159, -1, - 208, -1, 195, -1, -1, 64, 200, 181, 91, 184, - 92, -1, -1, 11, 200, 183, 91, 184, 92, -1, - 209, -1, 184, 180, -1, 184, 182, -1, 184, 185, - -1, 184, 188, -1, 184, 191, -1, -1, 57, 200, - 186, 91, 187, 92, -1, 209, -1, 187, 58, 199, - 91, 207, 92, -1, 187, 65, 91, 195, 92, -1, - -1, 85, 200, 189, 91, 190, 92, -1, 209, -1, - 190, 58, 199, 91, 207, 92, -1, 190, 65, 91, - 195, 92, -1, -1, 86, 200, 192, 91, 193, 92, - -1, 209, -1, 193, 58, 199, 91, 207, 92, -1, - 193, 185, -1, 209, -1, 194, 208, -1, 209, -1, - 195, 206, -1, 199, -1, 199, -1, 199, -1, 209, - -1, 203, -1, 202, -1, 209, -1, 203, -1, 209, - -1, 203, -1, 3, -1, 4, -1, 5, -1, 209, - -1, 205, -1, 203, -1, 205, 203, -1, 3, -1, - 4, -1, 3, -1, 4, -1, 5, -1, 3, -1, - 4, -1, -1 -}; - -/* YYRLINE[YYN] -- source line where rule number YYN was defined. */ -static const yytype_uint16 yyrline[] = -{ - 0, 216, 216, 217, 218, 219, 230, 231, 247, 248, - 249, 250, 251, 252, 253, 254, 255, 256, 257, 258, - 259, 260, 261, 262, 263, 274, 297, 312, 311, 339, - 340, 664, 676, 675, 702, 703, 798, 805, 826, 825, - 865, 866, 878, 877, 889, 888, 934, 938, 942, 946, - 951, 950, 965, 966, 967, 975, 994, 998, 1002, 1010, - 1018, 1026, 1034, 1042, 1060, 1064, 1072, 1090, 1094, 1102, - 1121, 1120, 1141, 1140, 1162, 1161, 1182, 1183, 1313, 1325, - 1330, 1337, 1343, 1356, 1363, 1376, 1382, 1388, 1394, 1399, - 1405, 1406, 1407, 1408, 1422, 1452, 1453, 1476, 1475, 1491, - 1492, 1493, 1494, 1495, 1496, 1497, 1498, 1499, 1500, 1501, - 1502, 1503, 1507, 1514, 1521, 1528, 1535, 1542, 1549, 1556, - 1563, 1570, 1577, 1581, 1582, 1594, 1598, 1599, 1621, 1654, - 1658, 1683, 1695, 1700, 1718, 1717, 1737, 1736, 1756, 1755, - 1775, 1774, 1794, 1793, 1813, 1812, 1832, 1831, 1851, 1852, - 1853, 1864, 1866, 1865, 1886, 1887, 1888, 1889, 1890, 1891, - 1892, 1893, 1966, 1967, 1968, 1969, 1970, 1971, 1972, 1973, - 1974, 1975, 1976, 1977, 1983, 1984, 2048, 2049, 2050, 2051, - 2052, 2053, 2054, 2055, 2056, 2057, 2058, 2127, 2144, 2184, - 2201, 2205, 2213, 2231, 2235, 2243, 2261, 2277, 2308, 2326, - 2346, 2366, 2371, 2382, 2388, 2407, 2423, 2445, 2444, 2467, - 2466, 2488, 2489, 2493, 2497, 2501, 2505, 2521, 2520, 2541, - 2542, 2554, 2569, 2568, 2589, 2590, 2607, 2622, 2621, 2642, - 2643, 2658, 2673, 2677, 2691, 2695, 2709, 2730, 2751, 2777, - 2782, 2794, 2806, 2811, 2822, 2826, 2840, 2844, 2848, 2861, - 2865, 2881, 2885, 2899, 2900, 2915, 2921, 2927, 2944, 2952, - 2958 -}; -#endif - -#if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE -/* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. - First, the terminals, then, starting at YYNTOKENS, nonterminals. */ -static const char *const yytname[] = -{ - "$end", "error", "$undefined", "EGG_NUMBER", "EGG_ULONG", "EGG_STRING", - "BEZIERCURVE", "BFACE", "BILLBOARD", "BILLBOARDCENTER", "BINORMAL", - "BUNDLE", "CLOSED", "COLLIDE", "COMMENT", "COMPONENT", "COORDSYSTEM", - "CV", "DART", "DNORMAL", "DRGBA", "DUV", "DXYZ", "DCS", "DISTANCE", - "DTREF", "DYNAMICVERTEXPOOL", "EXTERNAL_FILE", "FLIGHT", "GROUP", "HIP", - "INTANGENT", "JOINT", "KNOTS", "INCLUDE", "INSTANCE", "LINE", "LOOP", - "MATERIAL", "MATRIX3", "MATRIX4", "MODEL", "MREF", "NORMAL", - "NURBSCURVE", "NURBSSURFACE", "OBJECTTYPE", "ORDER", "OUTTANGENT", - "POINTLIGHT", "POLYGON", "REF", "RGBA", "ROTATE", "ROTX", "ROTY", "ROTZ", - "SANIM", "SCALAR", "SCALE", "SEQUENCE", "SHADING", "SWITCH", - "SWITCHCONDITION", "TABLE", "TABLE_V", "TAG", "TANGENT", "TEXLIST", - "TEXTURE", "TLENGTHS", "TRANSFORM", "TRANSLATE", "TREF", "TRIANGLEFAN", - "TRIANGLESTRIP", "TRIM", "TXT", "UKNOTS", "UV", "VKNOTS", "VERTEX", - "VERTEXANIM", "VERTEXPOOL", "VERTEXREF", "XFMANIM", "XFMSANIM", - "START_EGG", "START_GROUP_BODY", "START_TEXTURE_BODY", - "START_PRIMITIVE_BODY", "'{'", "'}'", "$accept", "grammar", "egg", - "node", "coordsystem", "comment", "texture", "@1", "texture_body", - "material", "@2", "material_body", "external_reference", "vertex_pool", - "@3", "vertex_pool_body", "vertex", "@4", "@5", "vertex_body", "@6", - "vertex_uv_body", "vertex_normal_body", "vertex_color_body", "group", - "@7", "joint", "@8", "instance", "@9", "group_body", "cs_type", - "collide_flags", "transform", "@10", "transform_body", "translate2d", - "translate3d", "rotate2d", "rotx", "roty", "rotz", "rotate3d", "scale2d", - "scale3d", "uniform_scale", "matrix3", "matrix3_body", "matrix4", - "matrix4_body", "group_vertex_ref", "group_vertex_membership", - "switchcondition", "switchcondition_body", "polygon", "@11", - "trianglefan", "@12", "trianglestrip", "@13", "point_light", "@14", - "line", "@15", "nurbs_surface", "@16", "nurbs_curve", "@17", - "primitive_component_body", "primitive_body", "@18", - "nurbs_surface_body", "nurbs_curve_body", "primitive_tref_body", - "primitive_texture_body", "primitive_material_body", - "primitive_normal_body", "primitive_color_body", "primitive_bface_body", - "primitive_vertex_ref", "nurbs_surface_order_body", - "nurbs_surface_uknots_body", "nurbs_surface_vknots_body", - "nurbs_surface_trim_body", "nurbs_surface_trim_loop_body", - "nurbs_curve_order_body", "nurbs_curve_knots_body", "table", "@19", - "bundle", "@20", "table_body", "sanim", "@21", "sanim_body", "xfmanim", - "@22", "xfmanim_body", "xfm_s_anim", "@23", "xfm_s_anim_body", - "integer_list", "real_list", "texture_name", "material_name", - "vertex_pool_name", "required_name", "optional_name", "required_string", - "optional_string", "string", "repeated_string", "repeated_string_body", - "real", "real_or_string", "integer", "empty", 0 -}; -#endif - -# ifdef YYPRINT -/* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to - token YYLEX-NUM. */ -static const yytype_uint16 yytoknum[] = -{ - 0, 256, 257, 258, 259, 260, 261, 262, 263, 264, - 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, - 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, - 285, 286, 287, 288, 289, 290, 291, 292, 293, 294, - 295, 296, 297, 298, 299, 300, 301, 302, 303, 304, - 305, 306, 307, 308, 309, 310, 311, 312, 313, 314, - 315, 316, 317, 318, 319, 320, 321, 322, 323, 324, - 325, 326, 327, 328, 329, 330, 331, 332, 333, 334, - 335, 336, 337, 338, 339, 340, 341, 342, 343, 344, - 345, 123, 125 -}; -# endif - -/* YYR1[YYN] -- Symbol number of symbol that rule YYN derives. */ -static const yytype_uint8 yyr1[] = -{ - 0, 93, 94, 94, 94, 94, 95, 95, 96, 96, - 96, 96, 96, 96, 96, 96, 96, 96, 96, 96, - 96, 96, 96, 96, 96, 97, 98, 100, 99, 101, - 101, 101, 103, 102, 104, 104, 105, 105, 107, 106, - 108, 108, 110, 109, 111, 109, 112, 112, 112, 112, - 113, 112, 112, 112, 112, 112, 114, 114, 114, 114, - 114, 114, 114, 114, 115, 115, 115, 116, 116, 116, - 118, 117, 120, 119, 122, 121, 123, 123, 123, 123, - 123, 123, 123, 123, 123, 123, 123, 123, 123, 123, - 123, 123, 123, 123, 124, 125, 125, 127, 126, 128, - 128, 128, 128, 128, 128, 128, 128, 128, 128, 128, - 128, 128, 129, 130, 131, 132, 133, 134, 135, 136, - 137, 138, 139, 140, 140, 141, 142, 142, 143, 144, - 144, 145, 146, 146, 148, 147, 150, 149, 152, 151, - 154, 153, 156, 155, 158, 157, 160, 159, 161, 161, - 161, 162, 163, 162, 162, 162, 162, 162, 162, 162, - 162, 162, 164, 164, 164, 164, 164, 164, 164, 164, - 164, 164, 164, 164, 164, 164, 165, 165, 165, 165, - 165, 165, 165, 165, 165, 165, 165, 166, 167, 168, - 169, 169, 169, 170, 170, 170, 171, 172, 173, 174, - 175, 176, 176, 177, 177, 178, 179, 181, 180, 183, - 182, 184, 184, 184, 184, 184, 184, 186, 185, 187, - 187, 187, 189, 188, 190, 190, 190, 192, 191, 193, - 193, 193, 194, 194, 195, 195, 196, 197, 198, 199, - 199, 200, 201, 201, 202, 202, 203, 203, 203, 204, - 204, 205, 205, 206, 206, 207, 207, 207, 208, 208, - 209 -}; - -/* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN. */ -static const yytype_uint8 yyr2[] = -{ - 0, 2, 2, 2, 2, 2, 1, 2, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 4, 5, 0, 7, 1, - 6, 2, 0, 6, 1, 6, 5, 6, 0, 6, - 1, 2, 0, 5, 0, 6, 1, 2, 3, 4, - 0, 7, 5, 5, 8, 8, 2, 3, 7, 7, - 7, 8, 7, 8, 3, 8, 8, 4, 9, 9, - 0, 6, 0, 6, 0, 6, 1, 6, 5, 7, - 7, 5, 5, 5, 5, 5, 5, 5, 6, 5, - 2, 2, 2, 2, 1, 1, 2, 0, 5, 1, - 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, - 2, 2, 5, 6, 4, 4, 4, 4, 7, 5, - 6, 4, 4, 1, 9, 4, 1, 16, 9, 1, - 6, 4, 11, 12, 0, 6, 0, 6, 0, 6, - 0, 6, 0, 6, 0, 6, 0, 6, 1, 5, - 5, 1, 0, 7, 5, 5, 5, 2, 5, 5, - 5, 6, 1, 5, 5, 5, 2, 5, 5, 5, - 5, 5, 5, 2, 5, 6, 1, 5, 5, 5, - 2, 5, 5, 5, 5, 5, 6, 1, 1, 1, - 3, 8, 8, 4, 9, 9, 1, 8, 2, 1, - 1, 1, 5, 1, 2, 1, 1, 0, 6, 0, - 6, 1, 2, 2, 2, 2, 2, 0, 6, 1, - 6, 5, 0, 6, 1, 6, 5, 0, 6, 1, - 6, 2, 1, 2, 1, 2, 1, 1, 1, 1, - 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, - 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, - 0 -}; - -/* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state - STATE-NUM when YYTABLE doesn't specify something else to do. Zero - means the default is an error. */ -static const yytype_uint16 yydefact[] = -{ - 0, 260, 260, 260, 260, 0, 2, 6, 3, 76, - 4, 29, 5, 151, 1, 246, 247, 248, 260, 0, - 260, 260, 260, 260, 260, 260, 260, 260, 260, 260, - 260, 260, 260, 260, 260, 7, 8, 9, 10, 11, - 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, - 22, 23, 24, 0, 0, 0, 260, 0, 0, 0, - 0, 260, 0, 0, 260, 0, 97, 0, 93, 90, - 91, 92, 260, 31, 0, 0, 0, 0, 0, 260, - 0, 0, 0, 157, 0, 241, 245, 244, 260, 0, - 70, 72, 74, 142, 0, 240, 239, 146, 144, 140, - 134, 207, 0, 136, 138, 38, 260, 0, 0, 0, - 0, 0, 0, 260, 0, 0, 0, 0, 0, 0, - 260, 0, 0, 258, 259, 0, 260, 0, 0, 0, - 260, 260, 260, 260, 0, 243, 242, 260, 0, 0, - 0, 0, 32, 0, 0, 0, 0, 0, 260, 0, - 0, 0, 0, 0, 253, 254, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 260, 0, - 260, 260, 232, 0, 0, 196, 152, 0, 189, 237, - 0, 0, 0, 0, 0, 0, 188, 0, 187, 236, - 0, 251, 0, 250, 249, 25, 0, 260, 260, 260, - 260, 260, 260, 260, 260, 260, 260, 27, 260, 260, - 260, 260, 78, 0, 260, 94, 84, 83, 82, 81, - 87, 86, 255, 256, 257, 0, 85, 0, 131, 0, - 89, 0, 99, 0, 233, 129, 0, 160, 260, 156, - 0, 158, 0, 0, 159, 0, 0, 155, 154, 0, - 26, 252, 36, 0, 0, 0, 0, 0, 34, 0, - 176, 0, 162, 0, 0, 0, 211, 260, 0, 0, - 0, 40, 0, 0, 0, 95, 77, 0, 88, 0, - 0, 0, 0, 0, 0, 0, 0, 98, 100, 101, - 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, - 0, 260, 30, 0, 148, 0, 0, 190, 0, 0, - 0, 161, 260, 71, 73, 75, 143, 260, 33, 0, - 0, 0, 0, 0, 0, 260, 0, 0, 147, 180, - 0, 0, 0, 0, 0, 260, 0, 0, 0, 0, - 0, 145, 173, 166, 141, 135, 260, 260, 260, 260, - 208, 212, 213, 214, 215, 216, 0, 137, 139, 42, - 39, 41, 37, 79, 80, 96, 0, 260, 260, 0, - 0, 0, 0, 0, 0, 260, 0, 0, 0, 153, - 0, 0, 0, 0, 193, 0, 238, 0, 0, 260, - 260, 0, 0, 0, 0, 260, 260, 0, 260, 0, - 0, 0, 0, 260, 260, 260, 260, 260, 209, 217, - 222, 227, 28, 0, 44, 0, 0, 0, 0, 123, - 0, 0, 126, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 206, 234, 0, 0, 0, 205, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 201, 0, 199, 0, 200, 0, 0, 0, 0, - 0, 0, 0, 0, 122, 0, 125, 0, 114, 0, - 115, 116, 117, 121, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 197, 0, 183, 185, 235, 179, - 181, 184, 182, 0, 178, 177, 169, 165, 167, 170, - 198, 168, 0, 164, 163, 0, 174, 171, 172, 260, - 260, 260, 260, 0, 46, 0, 0, 0, 0, 0, - 0, 119, 0, 112, 0, 128, 130, 149, 150, 0, - 0, 0, 0, 35, 186, 175, 260, 0, 0, 219, - 0, 224, 0, 229, 0, 0, 0, 260, 43, 47, - 0, 0, 0, 0, 0, 0, 120, 113, 192, 191, - 0, 0, 0, 203, 210, 260, 0, 218, 260, 0, - 223, 260, 228, 231, 0, 0, 0, 0, 0, 48, - 45, 0, 0, 0, 0, 118, 195, 194, 202, 204, - 0, 260, 0, 260, 0, 0, 0, 0, 0, 0, - 0, 50, 49, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 52, 0, 0, 53, 0, - 0, 132, 0, 0, 0, 0, 221, 0, 226, 0, - 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, - 133, 0, 0, 220, 225, 230, 0, 0, 0, 0, - 0, 0, 67, 0, 0, 0, 51, 56, 124, 0, - 55, 54, 0, 0, 0, 0, 0, 0, 0, 0, - 57, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 66, 65, 0, 0, 0, 0, 0, 0, 0, 69, - 68, 59, 62, 0, 60, 0, 58, 0, 63, 61, - 0, 127 -}; - -/* YYDEFGOTO[NTERM-NUM]. */ -static const yytype_int16 yydefgoto[] = -{ - -1, 5, 6, 68, 36, 37, 38, 267, 10, 39, - 201, 257, 40, 41, 151, 270, 361, 413, 471, 523, - 630, 648, 607, 609, 42, 138, 43, 139, 44, 140, - 8, 214, 274, 69, 119, 231, 288, 289, 290, 291, - 292, 293, 294, 295, 296, 297, 298, 417, 299, 420, - 70, 233, 71, 167, 45, 146, 46, 149, 47, 150, - 48, 145, 49, 141, 50, 144, 51, 143, 303, 12, - 238, 261, 259, 187, 185, 177, 180, 182, 174, 83, - 454, 462, 464, 460, 572, 445, 440, 52, 147, 352, - 466, 265, 353, 467, 548, 354, 468, 550, 355, 469, - 552, 171, 441, 188, 178, 385, 179, 84, 134, 85, - 95, 192, 193, 498, 225, 175, 96 -}; - -/* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing - STATE-NUM. */ -#define YYPACT_NINF -402 -static const yytype_int16 yypact[] = -{ - 187, -402, -402, -402, -402, 13, 995, -402, 1259, -402, - 115, -402, 255, -402, -402, -402, -402, -402, 286, -84, - 286, 286, 286, 286, 286, 286, 286, 286, 286, 286, - 286, 286, 286, 286, 286, -402, -402, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - -402, -402, -402, 90, -63, 22, 286, 42, 65, 81, - 120, 286, 138, 150, 286, 164, -402, 169, -402, -402, - -402, -402, 286, -402, 181, 192, 190, 191, 203, 286, - 205, 219, 224, -402, 227, -402, -402, -402, 286, 228, - -402, -402, -402, -402, 231, -402, -402, -402, -402, -402, - -402, -402, 232, -402, -402, -402, 286, 286, 213, 234, - 301, 326, 192, 286, 236, 192, 125, 241, 192, 242, - -402, 247, 192, -402, -402, 253, 286, 213, 213, 260, - 286, 286, -402, 286, 143, -402, -402, 286, 261, 262, - 263, 272, -402, 273, 275, 285, 288, 294, 286, 295, - 296, 299, 300, 208, -402, -402, 213, 286, 303, 304, - 305, 307, 309, 311, 332, 313, 302, 314, 286, 315, - -402, 192, -402, 332, 316, -402, -402, 317, -402, -402, - 6, 213, 14, 213, 332, 318, -402, 319, -402, -402, - 172, -402, 321, 286, -402, -402, 322, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - -402, 286, -402, 213, -402, -402, -402, -402, -402, -402, - -402, -402, -402, -402, -402, 325, -402, 213, -402, 328, - -402, 306, -402, 60, -402, -402, 329, -402, -402, -402, - 75, -402, 213, 80, -402, 213, 331, -402, -402, 327, - -402, -402, -402, 921, 1104, 1177, 373, 109, -402, 211, - -402, 146, -402, 397, 708, 121, -402, -402, 733, 747, - 144, -402, 334, 335, 51, -402, -402, 213, -402, 339, - 347, 350, 352, 353, 354, 356, 357, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - 359, 286, -402, 116, -402, 286, 360, -402, 286, 362, - 213, -402, 286, -402, -402, -402, -402, 286, -402, 367, - 368, 369, 370, 371, 372, 286, 376, 377, -402, -402, - 378, 381, 383, 384, 386, 286, 391, 392, 393, 396, - 405, -402, -402, -402, -402, -402, 286, 286, 286, 286, - -402, -402, -402, -402, -402, -402, 174, -402, -402, 192, - -402, -402, -402, -402, -402, -402, 100, 213, 213, 213, - 213, 213, 213, 213, 213, 286, 406, 407, 408, -402, - 213, 213, 213, 213, -402, 409, -402, 411, 192, -402, - 286, 213, 192, 213, 413, 286, 286, 192, 286, 213, - 192, 213, 414, 286, 286, -402, -402, -402, -402, -402, - -402, -402, -402, 415, -402, 416, 161, 417, 213, -402, - 418, 213, -402, 7, 419, 420, 422, 44, 213, 423, - 332, 213, 213, 213, 213, 213, 213, 424, 332, 425, - 426, 213, -402, 427, 24, 428, -402, 31, 332, 429, - 430, 431, 432, 34, 440, 192, 43, 332, 441, 442, - 71, -402, 443, 213, 444, 213, 446, 447, 448, 449, - 213, 450, 213, 453, -402, 213, -402, 213, -402, 213, - -402, -402, -402, -402, 56, 58, 454, 455, 55, 99, - 213, 213, 213, 213, -402, 457, -402, -402, -402, -402, - -402, -402, -402, 458, -402, -402, -402, -402, -402, -402, - -402, -402, 460, -402, -402, 463, -402, -402, -402, -402, - -402, -402, -402, 118, 213, 213, 213, 213, 213, 213, - 213, -402, 464, -402, 465, -402, -402, -402, -402, 466, - 467, 213, 213, -402, -402, -402, -402, 135, 72, -402, - 175, -402, 87, -402, 83, 470, 476, 286, -402, 213, - 209, 213, 213, 213, 213, 477, -402, -402, -402, -402, - 478, 479, 77, -402, -402, 286, 481, -402, 286, 484, - -402, 286, -402, -402, 286, 485, 213, 213, 486, 213, - -402, 487, 213, 213, 213, -402, -402, -402, -402, -402, - 489, -402, 492, -402, 493, 213, 213, 62, 213, 102, - 213, -402, -402, 494, 497, 213, 213, 332, 63, 332, - 66, 332, 213, 213, 86, -402, 213, 89, -402, 213, - 213, -402, 499, 213, 213, 500, -402, 504, -402, 505, - 213, 213, 286, 507, -402, 286, 508, 213, 47, 213, - -402, 213, 213, -402, -402, -402, 509, 510, 213, 213, - 213, 213, -402, 512, 92, 513, -402, 213, -402, 213, - -402, -402, 213, 213, 213, 213, 213, 286, 514, 213, - -402, 213, 213, 213, 213, 213, 213, 213, 213, 213, - 213, 516, 518, 213, 213, 213, 213, 213, 213, 213, - -402, -402, 520, 521, 522, 68, 73, 523, 213, -402, - -402, -402, -402, 527, -402, 528, -402, 213, -402, -402, - 213, -402 -}; - -/* YYPGOTO[NTERM-NUM]. */ -static const yytype_int16 yypgoto[] = -{ - -402, -402, -402, 482, -402, -402, -402, -402, 110, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -61, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - 151, -402, -402, -9, -402, -402, -402, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -402, -402, -402, -402, - -402, -402, -402, -402, -402, -402, -258, -402, -402, 112, - -402, -402, -402, -145, -139, -119, -279, -291, -263, 26, - -402, -402, -402, -402, -402, -402, -402, -261, -402, -402, - -402, -19, -44, -402, -402, -402, -402, -402, -402, -402, - -402, 436, -401, -402, -402, 170, 178, 9, -73, -402, - -6, 387, -402, 1, -165, -66, 709 -}; - -/* YYTABLE[YYPACT[STATE-NUM]]. What to do in state STATE-NUM. If - positive, shift that token. If negative, reduce the rule which - number is the opposite. If zero, do what YYDEFACT says. - If YYTABLE_NINF, syntax error. */ -#define YYTABLE_NINF -1 -static const yytype_uint16 yytable[] = -{ - 53, 73, 53, 342, 351, 463, 465, 88, 236, 125, - 154, 155, 86, 14, 86, 86, 86, 86, 86, 246, - 86, 86, 86, 86, 86, 240, 86, 86, 107, 89, - 90, 91, 92, 93, 243, 97, 98, 99, 100, 101, - 163, 103, 104, 240, 159, 161, 162, 154, 155, 165, - 86, 243, 169, 240, 15, 16, 17, 663, 86, 154, - 155, 154, 155, 243, 196, 109, 154, 155, 664, 154, - 155, 154, 155, 117, 240, 207, 154, 155, 15, 16, - 17, 624, 135, 15, 16, 17, 15, 16, 17, 15, - 16, 17, 15, 16, 17, 15, 16, 17, 241, 478, - 86, 153, 447, 154, 155, 234, 244, 135, 515, 156, - 456, 300, 444, 108, 665, 152, 500, 106, 301, 243, - 453, 26, 627, 502, 234, 439, 508, 191, 181, 183, - 575, 135, 346, 110, 451, 511, 483, 576, 272, 666, - 554, 489, 135, 364, 347, 581, 346, 537, 531, 166, - 533, 215, 488, 330, 625, 636, 111, 213, 638, 377, - 712, 555, 191, 516, 577, 714, 305, 317, 378, 598, - 556, 308, 112, 72, 584, 123, 124, 642, 347, 582, - 645, 415, 242, 677, 245, 30, 66, 251, 331, 332, - 26, 538, 347, 333, 628, 123, 124, 557, 334, 30, - 618, 318, 620, 94, 335, 135, 348, 349, 379, 102, - 558, 113, 105, 350, 273, 336, 154, 155, 319, 337, - 348, 349, 338, 249, 339, 359, 340, 574, 277, 115, - 82, 554, 72, 578, 306, 195, 360, 309, 341, 114, - 579, 116, 473, 307, 320, 66, 310, 53, 53, 53, - 121, 450, 555, 321, 322, 118, 449, 129, 323, 459, - 120, 556, 74, 324, 458, 487, 412, 580, 365, 325, - 75, 443, 122, 495, 1, 2, 3, 4, 366, 452, - 326, 126, 127, 503, 327, 329, 351, 343, 557, 15, - 16, 17, 512, 414, 128, 82, 130, 76, 77, 380, - 212, 590, 382, 328, 123, 124, 158, 78, 186, 189, - 131, 384, 256, 79, 599, 132, 263, 264, 133, 137, - 268, 269, 142, 148, 80, 157, 446, 164, 81, 123, - 124, 160, 168, 170, 455, 222, 223, 224, 173, 82, - 86, 86, 86, 86, 176, 279, 280, 73, 253, 254, - 255, 184, 197, 198, 199, 408, 409, 410, 411, 281, - 282, 283, 284, 200, 202, 285, 203, 416, 418, 421, - 423, 424, 425, 426, 427, 428, 204, 356, 286, 205, - 74, 433, 434, 435, 436, 206, 208, 209, 75, 510, - 210, 211, 181, 227, 183, 216, 217, 218, 287, 219, - 181, 220, 183, 221, 74, 226, 228, 230, 237, 239, - 247, 248, 75, 250, 252, 76, 77, 276, 312, 475, - 278, 302, 477, 311, 479, 78, 362, 363, 484, 485, - 367, 79, 181, 183, 490, 491, 492, 493, 368, 76, - 77, 369, 80, 370, 371, 372, 81, 373, 374, 78, - 375, 381, 635, 383, 637, 79, 639, 82, 388, 389, - 390, 391, 392, 393, 560, 316, 80, 395, 396, 397, - 81, 524, 398, 526, 399, 400, 528, 401, 529, 376, - 530, 82, 403, 404, 405, 532, 534, 406, 35, 344, - 386, 539, 540, 541, 542, 387, 407, 430, 431, 432, - 547, 437, 438, 394, 448, 457, 470, 472, 583, 474, - 476, 480, 481, 402, 482, 486, 494, 496, 497, 499, - 501, 504, 505, 506, 507, 559, 524, 561, 562, 563, - 564, 565, 509, 513, 514, 517, 518, 519, 520, 521, - 522, 525, 570, 571, 527, 429, 535, 536, 585, 543, - 544, 86, 545, 386, 546, 229, 566, 567, 568, 569, - 589, 586, 591, 592, 593, 594, 588, 587, 190, 595, - 596, 597, 601, 186, 189, 603, 606, 611, 605, 613, - 617, 186, 189, 619, 621, 0, 631, 608, 610, 632, - 612, 650, 653, 614, 615, 616, 654, 655, 659, 661, - 0, 670, 671, 676, 679, 688, 622, 623, 700, 626, - 701, 629, 709, 710, 711, 716, 633, 634, 643, 718, - 719, 646, 0, 640, 641, 0, 0, 644, 0, 0, - 647, 649, 0, 0, 651, 652, 658, 0, 0, 660, - 0, 656, 657, 0, 0, 0, 0, 0, 662, 0, - 667, 0, 668, 669, 0, 0, 0, 0, 678, 672, - 673, 674, 675, 0, 0, 0, 0, 0, 680, 0, - 681, 687, 0, 682, 683, 684, 685, 686, 0, 0, - 689, 0, 690, 691, 692, 693, 694, 695, 696, 697, - 698, 699, 0, 0, 702, 703, 704, 705, 706, 707, - 708, 0, 0, 0, 0, 0, 713, 715, 0, 717, - 7, 9, 11, 13, 0, 74, 0, 0, 720, 0, - 0, 721, 0, 75, 0, 0, 0, 87, 0, 87, - 87, 87, 87, 87, 0, 87, 87, 87, 87, 87, - 74, 87, 87, 0, 0, 0, 0, 0, 75, 0, - 76, 77, 0, 600, 74, 0, 602, 0, 0, 604, - 78, 0, 75, 0, 0, 87, 79, 0, 0, 0, - 0, 0, 0, 87, 0, 76, 77, 80, 0, 0, - 0, 81, 0, 0, 0, 78, 0, 0, 0, 76, - 77, 79, 82, 0, 0, 0, 0, 136, 0, 78, - 345, 0, 80, 0, 0, 79, 81, 0, 0, 0, - 0, 0, 0, 0, 0, 87, 80, 82, 0, 0, - 81, 0, 136, 0, 0, 357, 0, 0, 0, 172, - 0, 82, 0, 0, 0, 0, 0, 0, 0, 358, - 0, 172, 194, 0, 0, 0, 136, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 136, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 194, 0, 232, - 235, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 9, 9, 9, 13, - 258, 260, 262, 13, 13, 266, 0, 13, 13, 271, - 136, 0, 0, 275, 15, 16, 17, 0, 0, 54, - 55, 0, 0, 0, 56, 18, 0, 19, 0, 57, - 0, 0, 0, 0, 58, 0, 0, 304, 20, 0, - 21, 0, 0, 22, 0, 0, 23, 24, 0, 25, - 0, 0, 59, 0, 0, 26, 27, 60, 0, 0, - 28, 29, 0, 0, 0, 0, 11, 0, 0, 61, - 0, 0, 0, 62, 63, 30, 0, 64, 0, 65, - 31, 0, 66, 0, 0, 32, 33, 0, 15, 16, - 17, 0, 0, 0, 34, 67, 0, 0, 0, 18, - 0, 19, 0, 313, 0, 0, 0, 0, 0, 0, - 0, 0, 20, 0, 21, 0, 0, 22, 0, 0, - 23, 24, 0, 25, 0, 0, 0, 0, 0, 26, - 27, 0, 0, 0, 28, 29, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 87, 87, 87, 87, 30, - 0, 0, 0, 0, 31, 0, 0, 0, 0, 32, - 33, 0, 0, 0, 0, 0, 419, 422, 34, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 442, 0, - 0, 0, 0, 0, 0, 0, 0, 15, 16, 17, - 0, 0, 54, 55, 461, 442, 442, 56, 18, 0, - 19, 0, 57, 0, 0, 0, 0, 58, 0, 0, - 0, 20, 0, 21, 0, 0, 22, 0, 0, 23, - 24, 0, 25, 0, 0, 59, 0, 0, 26, 27, - 60, 0, 0, 28, 29, 0, 0, 0, 0, 0, - 0, 0, 61, 0, 0, 0, 62, 63, 30, 0, - 64, 0, 65, 31, 0, 66, 0, 0, 32, 33, - 15, 16, 17, 0, 0, 54, 55, 34, 67, 0, - 56, 18, 0, 19, 0, 57, 314, 0, 0, 0, - 58, 0, 0, 0, 20, 0, 21, 0, 0, 22, - 0, 0, 23, 24, 0, 25, 0, 0, 59, 0, - 0, 26, 27, 60, 0, 0, 28, 29, 266, 549, - 551, 553, 0, 0, 0, 61, 0, 0, 0, 62, - 63, 30, 0, 64, 0, 65, 31, 0, 66, 0, - 0, 32, 33, 0, 0, 573, 0, 0, 0, 0, - 34, 67, 15, 16, 17, 0, 87, 54, 55, 315, - 0, 0, 56, 18, 0, 19, 0, 57, 0, 0, - 0, 0, 58, 0, 0, 0, 20, 0, 21, 0, - 0, 22, 0, 0, 23, 24, 0, 25, 0, 0, - 59, 0, 0, 26, 27, 60, 0, 0, 28, 29, - 442, 0, 442, 0, 0, 0, 0, 61, 0, 0, - 0, 62, 63, 30, 0, 64, 0, 65, 31, 0, - 66, 0, 0, 32, 33, 0, 0, 0, 0, 0, - 0, 0, 34, 67 -}; - -static const yytype_int16 yycheck[] = -{ - 6, 10, 8, 261, 265, 406, 407, 91, 173, 75, - 3, 4, 18, 0, 20, 21, 22, 23, 24, 184, - 26, 27, 28, 29, 30, 19, 32, 33, 91, 20, - 21, 22, 23, 24, 20, 26, 27, 28, 29, 30, - 113, 32, 33, 19, 110, 111, 112, 3, 4, 115, - 56, 20, 118, 19, 3, 4, 5, 10, 64, 3, - 4, 3, 4, 20, 137, 56, 3, 4, 21, 3, - 4, 3, 4, 64, 19, 148, 3, 4, 3, 4, - 5, 19, 88, 3, 4, 5, 3, 4, 5, 3, - 4, 5, 3, 4, 5, 3, 4, 5, 92, 92, - 106, 107, 393, 3, 4, 171, 92, 113, 37, 108, - 401, 51, 391, 91, 67, 106, 92, 27, 58, 20, - 399, 44, 20, 92, 190, 388, 92, 133, 127, 128, - 58, 137, 11, 91, 397, 92, 92, 65, 211, 92, - 22, 432, 148, 92, 57, 58, 11, 92, 92, 24, - 92, 157, 431, 7, 92, 92, 91, 156, 92, 43, - 92, 43, 168, 92, 92, 92, 91, 58, 52, 92, - 52, 91, 91, 58, 91, 3, 4, 91, 57, 92, - 91, 81, 181, 91, 183, 64, 71, 193, 42, 43, - 44, 92, 57, 47, 92, 3, 4, 79, 52, 64, - 601, 92, 603, 25, 58, 211, 85, 86, 92, 31, - 92, 91, 34, 92, 213, 69, 3, 4, 7, 73, - 85, 86, 76, 51, 78, 81, 80, 92, 227, 91, - 84, 22, 58, 58, 240, 92, 92, 243, 92, 61, - 65, 91, 81, 242, 33, 71, 245, 253, 254, 255, - 72, 396, 43, 42, 43, 91, 395, 79, 47, 404, - 91, 52, 7, 52, 403, 430, 92, 92, 274, 58, - 15, 390, 91, 438, 87, 88, 89, 90, 277, 398, - 69, 91, 91, 448, 73, 259, 547, 261, 79, 3, - 4, 5, 457, 359, 91, 84, 91, 42, 43, 305, - 92, 92, 308, 92, 3, 4, 5, 52, 130, 131, - 91, 310, 200, 58, 572, 91, 204, 205, 91, 91, - 208, 209, 91, 91, 69, 91, 392, 91, 73, 3, - 4, 5, 91, 91, 400, 3, 4, 5, 91, 84, - 346, 347, 348, 349, 91, 39, 40, 356, 197, 198, - 199, 91, 91, 91, 91, 346, 347, 348, 349, 53, - 54, 55, 56, 91, 91, 59, 91, 366, 367, 368, - 369, 370, 371, 372, 373, 374, 91, 267, 72, 91, - 7, 380, 381, 382, 383, 91, 91, 91, 15, 455, - 91, 91, 391, 91, 393, 92, 92, 92, 92, 92, - 399, 92, 401, 92, 7, 92, 92, 92, 92, 92, - 92, 92, 15, 92, 92, 42, 43, 92, 91, 418, - 92, 92, 421, 92, 423, 52, 92, 92, 427, 428, - 91, 58, 431, 432, 433, 434, 435, 436, 91, 42, - 43, 91, 69, 91, 91, 91, 73, 91, 91, 52, - 91, 91, 617, 91, 619, 58, 621, 84, 91, 91, - 91, 91, 91, 91, 525, 92, 69, 91, 91, 91, - 73, 470, 91, 472, 91, 91, 475, 91, 477, 301, - 479, 84, 91, 91, 91, 484, 485, 91, 6, 92, - 312, 490, 491, 492, 493, 317, 91, 91, 91, 91, - 519, 92, 91, 325, 91, 91, 91, 91, 552, 92, - 92, 92, 92, 335, 92, 92, 92, 92, 92, 92, - 92, 92, 92, 92, 92, 524, 525, 526, 527, 528, - 529, 530, 92, 92, 92, 92, 92, 91, 91, 91, - 91, 91, 541, 542, 91, 375, 92, 92, 554, 92, - 92, 557, 92, 375, 91, 168, 92, 92, 92, 92, - 559, 91, 561, 562, 563, 564, 557, 91, 132, 92, - 92, 92, 91, 395, 396, 91, 91, 91, 584, 92, - 91, 403, 404, 91, 91, -1, 92, 586, 587, 92, - 589, 92, 92, 592, 593, 594, 92, 92, 91, 91, - -1, 92, 92, 91, 91, 91, 605, 606, 92, 608, - 92, 610, 92, 92, 92, 92, 615, 616, 624, 92, - 92, 627, -1, 622, 623, -1, -1, 626, -1, -1, - 629, 630, -1, -1, 633, 634, 642, -1, -1, 645, - -1, 640, 641, -1, -1, -1, -1, -1, 647, -1, - 649, -1, 651, 652, -1, -1, -1, -1, 664, 658, - 659, 660, 661, -1, -1, -1, -1, -1, 667, -1, - 669, 677, -1, 672, 673, 674, 675, 676, -1, -1, - 679, -1, 681, 682, 683, 684, 685, 686, 687, 688, - 689, 690, -1, -1, 693, 694, 695, 696, 697, 698, - 699, -1, -1, -1, -1, -1, 705, 706, -1, 708, - 1, 2, 3, 4, -1, 7, -1, -1, 717, -1, - -1, 720, -1, 15, -1, -1, -1, 18, -1, 20, - 21, 22, 23, 24, -1, 26, 27, 28, 29, 30, - 7, 32, 33, -1, -1, -1, -1, -1, 15, -1, - 42, 43, -1, 575, 7, -1, 578, -1, -1, 581, - 52, -1, 15, -1, -1, 56, 58, -1, -1, -1, - -1, -1, -1, 64, -1, 42, 43, 69, -1, -1, - -1, 73, -1, -1, -1, 52, -1, -1, -1, 42, - 43, 58, 84, -1, -1, -1, -1, 88, -1, 52, - 92, -1, 69, -1, -1, 58, 73, -1, -1, -1, - -1, -1, -1, -1, -1, 106, 69, 84, -1, -1, - 73, -1, 113, -1, -1, 92, -1, -1, -1, 120, - -1, 84, -1, -1, -1, -1, -1, -1, -1, 92, - -1, 132, 133, -1, -1, -1, 137, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 148, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, 168, -1, 170, - 171, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, 197, 198, 199, 200, - 201, 202, 203, 204, 205, 206, -1, 208, 209, 210, - 211, -1, -1, 214, 3, 4, 5, -1, -1, 8, - 9, -1, -1, -1, 13, 14, -1, 16, -1, 18, - -1, -1, -1, -1, 23, -1, -1, 238, 27, -1, - 29, -1, -1, 32, -1, -1, 35, 36, -1, 38, - -1, -1, 41, -1, -1, 44, 45, 46, -1, -1, - 49, 50, -1, -1, -1, -1, 267, -1, -1, 58, - -1, -1, -1, 62, 63, 64, -1, 66, -1, 68, - 69, -1, 71, -1, -1, 74, 75, -1, 3, 4, - 5, -1, -1, -1, 83, 84, -1, -1, -1, 14, - -1, 16, -1, 92, -1, -1, -1, -1, -1, -1, - -1, -1, 27, -1, 29, -1, -1, 32, -1, -1, - 35, 36, -1, 38, -1, -1, -1, -1, -1, 44, - 45, -1, -1, -1, 49, 50, -1, -1, -1, -1, - -1, -1, -1, -1, -1, 346, 347, 348, 349, 64, - -1, -1, -1, -1, 69, -1, -1, -1, -1, 74, - 75, -1, -1, -1, -1, -1, 367, 368, 83, -1, - -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, - -1, -1, -1, -1, -1, -1, -1, -1, 389, -1, - -1, -1, -1, -1, -1, -1, -1, 3, 4, 5, - -1, -1, 8, 9, 405, 406, 407, 13, 14, -1, - 16, -1, 18, -1, -1, -1, -1, 23, -1, -1, - -1, 27, -1, 29, -1, -1, 32, -1, -1, 35, - 36, -1, 38, -1, -1, 41, -1, -1, 44, 45, - 46, -1, -1, 49, 50, -1, -1, -1, -1, -1, - -1, -1, 58, -1, -1, -1, 62, 63, 64, -1, - 66, -1, 68, 69, -1, 71, -1, -1, 74, 75, - 3, 4, 5, -1, -1, 8, 9, 83, 84, -1, - 13, 14, -1, 16, -1, 18, 92, -1, -1, -1, - 23, -1, -1, -1, 27, -1, 29, -1, -1, 32, - -1, -1, 35, 36, -1, 38, -1, -1, 41, -1, - -1, 44, 45, 46, -1, -1, 49, 50, 519, 520, - 521, 522, -1, -1, -1, 58, -1, -1, -1, 62, - 63, 64, -1, 66, -1, 68, 69, -1, 71, -1, - -1, 74, 75, -1, -1, 546, -1, -1, -1, -1, - 83, 84, 3, 4, 5, -1, 557, 8, 9, 92, - -1, -1, 13, 14, -1, 16, -1, 18, -1, -1, - -1, -1, 23, -1, -1, -1, 27, -1, 29, -1, - -1, 32, -1, -1, 35, 36, -1, 38, -1, -1, - 41, -1, -1, 44, 45, 46, -1, -1, 49, 50, - 601, -1, 603, -1, -1, -1, -1, 58, -1, -1, - -1, 62, 63, 64, -1, 66, -1, 68, 69, -1, - 71, -1, -1, 74, 75, -1, -1, -1, -1, -1, - -1, -1, 83, 84 -}; - -/* YYSTOS[STATE-NUM] -- The (internal number of the) accessing - symbol of state STATE-NUM. */ -static const yytype_uint8 yystos[] = -{ - 0, 87, 88, 89, 90, 94, 95, 209, 123, 209, - 101, 209, 162, 209, 0, 3, 4, 5, 14, 16, - 27, 29, 32, 35, 36, 38, 44, 45, 49, 50, - 64, 69, 74, 75, 83, 96, 97, 98, 99, 102, - 105, 106, 117, 119, 121, 147, 149, 151, 153, 155, - 157, 159, 180, 203, 8, 9, 13, 18, 23, 41, - 46, 58, 62, 63, 66, 68, 71, 84, 96, 126, - 143, 145, 58, 126, 7, 15, 42, 43, 52, 58, - 69, 73, 84, 172, 200, 202, 203, 209, 91, 200, - 200, 200, 200, 200, 199, 203, 209, 200, 200, 200, - 200, 200, 199, 200, 200, 199, 27, 91, 91, 200, - 91, 91, 91, 91, 199, 91, 91, 200, 91, 127, - 91, 199, 91, 3, 4, 208, 91, 91, 91, 199, - 91, 91, 91, 91, 201, 203, 209, 91, 118, 120, - 122, 156, 91, 160, 158, 154, 148, 181, 91, 150, - 152, 107, 200, 203, 3, 4, 206, 91, 5, 208, - 5, 208, 208, 201, 91, 208, 24, 146, 91, 208, - 91, 194, 209, 91, 171, 208, 91, 168, 197, 199, - 169, 206, 170, 206, 91, 167, 199, 166, 196, 199, - 194, 203, 204, 205, 209, 92, 201, 91, 91, 91, - 91, 103, 91, 91, 91, 91, 91, 201, 91, 91, - 91, 91, 92, 206, 124, 203, 92, 92, 92, 92, - 92, 92, 3, 4, 5, 207, 92, 91, 92, 204, - 92, 128, 209, 144, 208, 209, 207, 92, 163, 92, - 19, 92, 206, 20, 92, 206, 207, 92, 92, 51, - 92, 203, 92, 123, 123, 123, 162, 104, 209, 165, - 209, 164, 209, 162, 162, 184, 209, 100, 162, 162, - 108, 209, 201, 206, 125, 209, 92, 206, 92, 39, - 40, 53, 54, 55, 56, 59, 72, 92, 129, 130, - 131, 132, 133, 134, 135, 136, 137, 138, 139, 141, - 51, 58, 92, 161, 209, 91, 203, 206, 91, 203, - 206, 92, 91, 92, 92, 92, 92, 58, 92, 7, - 33, 42, 43, 47, 52, 58, 69, 73, 92, 172, - 7, 42, 43, 47, 52, 58, 69, 73, 76, 78, - 80, 92, 159, 172, 92, 92, 11, 57, 85, 86, - 92, 180, 182, 185, 188, 191, 101, 92, 92, 81, - 92, 109, 92, 92, 92, 203, 206, 91, 91, 91, - 91, 91, 91, 91, 91, 91, 199, 43, 52, 92, - 203, 91, 203, 91, 206, 198, 199, 199, 91, 91, - 91, 91, 91, 91, 199, 91, 91, 91, 91, 91, - 91, 91, 199, 91, 91, 91, 91, 91, 200, 200, - 200, 200, 92, 110, 208, 81, 206, 140, 206, 209, - 142, 206, 209, 206, 206, 206, 206, 206, 206, 198, - 91, 91, 91, 206, 206, 206, 206, 92, 91, 171, - 179, 195, 209, 168, 169, 178, 208, 170, 91, 167, - 166, 171, 168, 169, 173, 208, 170, 91, 167, 166, - 176, 209, 174, 195, 175, 195, 183, 186, 189, 192, - 91, 111, 91, 81, 92, 206, 92, 206, 92, 206, - 92, 92, 92, 92, 206, 206, 92, 207, 169, 170, - 206, 206, 206, 206, 92, 207, 92, 92, 206, 92, - 92, 92, 92, 207, 92, 92, 92, 92, 92, 92, - 208, 92, 207, 92, 92, 37, 92, 92, 92, 91, - 91, 91, 91, 112, 206, 91, 206, 91, 206, 206, - 206, 92, 206, 92, 206, 92, 92, 92, 92, 206, - 206, 206, 206, 92, 92, 92, 91, 184, 187, 209, - 190, 209, 193, 209, 22, 43, 52, 79, 92, 206, - 112, 206, 206, 206, 206, 206, 92, 92, 92, 92, - 206, 206, 177, 209, 92, 58, 65, 92, 58, 65, - 92, 58, 92, 185, 91, 203, 91, 91, 200, 206, - 92, 206, 206, 206, 206, 92, 92, 92, 92, 159, - 199, 91, 199, 91, 199, 203, 91, 115, 206, 116, - 206, 91, 206, 92, 206, 206, 206, 91, 195, 91, - 195, 91, 206, 206, 19, 92, 206, 20, 92, 206, - 113, 92, 92, 206, 206, 207, 92, 207, 92, 207, - 206, 206, 91, 203, 206, 91, 203, 206, 114, 206, - 92, 206, 206, 92, 92, 92, 206, 206, 203, 91, - 203, 91, 206, 10, 21, 67, 92, 206, 206, 206, - 92, 92, 206, 206, 206, 206, 91, 91, 203, 91, - 206, 206, 206, 206, 206, 206, 206, 203, 91, 206, - 206, 206, 206, 206, 206, 206, 206, 206, 206, 206, - 92, 92, 206, 206, 206, 206, 206, 206, 206, 92, - 92, 92, 92, 206, 92, 206, 92, 206, 92, 92, - 206, 206 -}; +/* Note: there must be only one dollar sign in this file. + It is replaced by the list of actions, each action + as one case of the switch. */ #define yyerrok (yyerrstatus = 0) #define yyclearin (yychar = YYEMPTY) -#define YYEMPTY (-2) +#define YYEMPTY -2 #define YYEOF 0 - #define YYACCEPT goto yyacceptlab -#define YYABORT goto yyabortlab -#define YYERROR goto yyerrorlab - - -/* Like YYERROR except do call yyerror. This remains here temporarily - to ease the transition to the new meaning of YYERROR, for GCC. +#define YYABORT goto yyabortlab +#define YYERROR goto yyerrlab1 +/* Like YYERROR except do call yyerror. + This remains here temporarily to ease the + transition to the new meaning of YYERROR, for GCC. Once GCC version 2 has supplanted version 1, this can go. */ - #define YYFAIL goto yyerrlab - #define YYRECOVERING() (!!yyerrstatus) - -#define YYBACKUP(Token, Value) \ +#define YYBACKUP(token, value) \ do \ if (yychar == YYEMPTY && yylen == 1) \ - { \ - yychar = (Token); \ - yylval = (Value); \ - yytoken = YYTRANSLATE (yychar); \ - YYPOPSTACK (1); \ + { yychar = (token), yylval = (value); \ + yychar1 = YYTRANSLATE (yychar); \ + YYPOPSTACK; \ goto yybackup; \ } \ else \ - { \ - yyerror (YY_("syntax error: cannot back up")); \ - YYERROR; \ - } \ -while (YYID (0)) - + { yyerror ("syntax error: cannot back up"); YYERROR; } \ +while (0) #define YYTERROR 1 #define YYERRCODE 256 - -/* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N]. - If N is 0, then set CURRENT to the empty location which ends - the previous symbol: RHS[0] (always defined). */ - -#define YYRHSLOC(Rhs, K) ((Rhs)[K]) -#ifndef YYLLOC_DEFAULT -# define YYLLOC_DEFAULT(Current, Rhs, N) \ - do \ - if (YYID (N)) \ - { \ - (Current).first_line = YYRHSLOC (Rhs, 1).first_line; \ - (Current).first_column = YYRHSLOC (Rhs, 1).first_column; \ - (Current).last_line = YYRHSLOC (Rhs, N).last_line; \ - (Current).last_column = YYRHSLOC (Rhs, N).last_column; \ - } \ - else \ - { \ - (Current).first_line = (Current).last_line = \ - YYRHSLOC (Rhs, 0).last_line; \ - (Current).first_column = (Current).last_column = \ - YYRHSLOC (Rhs, 0).last_column; \ - } \ - while (YYID (0)) +#ifndef YYPURE +#define YYLEX yylex() #endif - -/* YY_LOCATION_PRINT -- Print the location on the stream. - This macro was not mandated originally: define only if we know - we won't break user code: when these are the locations we know. */ - -#ifndef YY_LOCATION_PRINT -# if YYLTYPE_IS_TRIVIAL -# define YY_LOCATION_PRINT(File, Loc) \ - fprintf (File, "%d.%d-%d.%d", \ - (Loc).first_line, (Loc).first_column, \ - (Loc).last_line, (Loc).last_column) -# else -# define YY_LOCATION_PRINT(File, Loc) ((void) 0) -# endif -#endif - - -/* YYLEX -- calling `yylex' with the right arguments. */ - +#ifdef YYPURE +#ifdef YYLSP_NEEDED #ifdef YYLEX_PARAM -# define YYLEX yylex (YYLEX_PARAM) +#define YYLEX yylex(&yylval, &yylloc, YYLEX_PARAM) #else -# define YYLEX yylex () +#define YYLEX yylex(&yylval, &yylloc) +#endif +#else /* not YYLSP_NEEDED */ +#ifdef YYLEX_PARAM +#define YYLEX yylex(&yylval, YYLEX_PARAM) +#else +#define YYLEX yylex(&yylval) +#endif +#endif /* not YYLSP_NEEDED */ #endif -/* Enable debugging if requested. */ -#if YYDEBUG +/* If nonreentrant, generate the variables here */ -# ifndef YYFPRINTF -# include /* INFRINGES ON USER NAME SPACE */ -# define YYFPRINTF fprintf -# endif +#ifndef YYPURE -# define YYDPRINTF(Args) \ -do { \ - if (yydebug) \ - YYFPRINTF Args; \ -} while (YYID (0)) +int yychar; /* the lookahead symbol */ +YYSTYPE yylval; /* the semantic value of the */ + /* lookahead symbol */ -# define YY_SYMBOL_PRINT(Title, Type, Value, Location) \ -do { \ - if (yydebug) \ - { \ - YYFPRINTF (stderr, "%s ", Title); \ - yy_symbol_print (stderr, \ - Type, Value); \ - YYFPRINTF (stderr, "\n"); \ - } \ -} while (YYID (0)) - - -/*--------------------------------. -| Print this symbol on YYOUTPUT. | -`--------------------------------*/ - -/*ARGSUSED*/ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_symbol_value_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep) -#else -static void -yy_symbol_value_print (yyoutput, yytype, yyvaluep) - FILE *yyoutput; - int yytype; - YYSTYPE const * const yyvaluep; +#ifdef YYLSP_NEEDED +YYLTYPE yylloc; /* location data for the lookahead */ + /* symbol */ #endif -{ - if (!yyvaluep) - return; -# ifdef YYPRINT - if (yytype < YYNTOKENS) - YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep); -# else - YYUSE (yyoutput); -# endif - switch (yytype) - { - default: - break; - } -} +int yynerrs; /* number of parse errors so far */ +#endif /* not YYPURE */ -/*--------------------------------. -| Print this symbol on YYOUTPUT. | -`--------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_symbol_print (FILE *yyoutput, int yytype, YYSTYPE const * const yyvaluep) -#else -static void -yy_symbol_print (yyoutput, yytype, yyvaluep) - FILE *yyoutput; - int yytype; - YYSTYPE const * const yyvaluep; +#if YYDEBUG != 0 +int yydebug; /* nonzero means print parse trace */ +/* Since this is uninitialized, it does not stop multiple parsers + from coexisting. */ #endif -{ - if (yytype < YYNTOKENS) - YYFPRINTF (yyoutput, "token %s (", yytname[yytype]); - else - YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]); - yy_symbol_value_print (yyoutput, yytype, yyvaluep); - YYFPRINTF (yyoutput, ")"); -} +/* YYINITDEPTH indicates the initial size of the parser's stacks */ -/*------------------------------------------------------------------. -| yy_stack_print -- Print the state stack from its BOTTOM up to its | -| TOP (included). | -`------------------------------------------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_stack_print (yytype_int16 *bottom, yytype_int16 *top) -#else -static void -yy_stack_print (bottom, top) - yytype_int16 *bottom; - yytype_int16 *top; -#endif -{ - YYFPRINTF (stderr, "Stack now"); - for (; bottom <= top; ++bottom) - YYFPRINTF (stderr, " %d", *bottom); - YYFPRINTF (stderr, "\n"); -} - -# define YY_STACK_PRINT(Bottom, Top) \ -do { \ - if (yydebug) \ - yy_stack_print ((Bottom), (Top)); \ -} while (YYID (0)) - - -/*------------------------------------------------. -| Report that the YYRULE is going to be reduced. | -`------------------------------------------------*/ - -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static void -yy_reduce_print (YYSTYPE *yyvsp, int yyrule) -#else -static void -yy_reduce_print (yyvsp, yyrule) - YYSTYPE *yyvsp; - int yyrule; -#endif -{ - int yynrhs = yyr2[yyrule]; - int yyi; - unsigned long int yylno = yyrline[yyrule]; - YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu):\n", - yyrule - 1, yylno); - /* The symbols being reduced. */ - for (yyi = 0; yyi < yynrhs; yyi++) - { - fprintf (stderr, " $%d = ", yyi + 1); - yy_symbol_print (stderr, yyrhs[yyprhs[yyrule] + yyi], - &(yyvsp[(yyi + 1) - (yynrhs)]) - ); - fprintf (stderr, "\n"); - } -} - -# define YY_REDUCE_PRINT(Rule) \ -do { \ - if (yydebug) \ - yy_reduce_print (yyvsp, Rule); \ -} while (YYID (0)) - -/* Nonzero means print parse trace. It is left uninitialized so that - multiple parsers can coexist. */ -int yydebug; -#else /* !YYDEBUG */ -# define YYDPRINTF(Args) -# define YY_SYMBOL_PRINT(Title, Type, Value, Location) -# define YY_STACK_PRINT(Bottom, Top) -# define YY_REDUCE_PRINT(Rule) -#endif /* !YYDEBUG */ - - -/* YYINITDEPTH -- initial size of the parser's stacks. */ #ifndef YYINITDEPTH -# define YYINITDEPTH 200 +#define YYINITDEPTH 200 #endif -/* YYMAXDEPTH -- maximum size the stacks can grow to (effective only - if the built-in stack extension method is used). +/* YYMAXDEPTH is the maximum size the stacks can grow to + (effective only if the built-in stack extension method is used). */ - Do not make this value too large; the results are undefined if - YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH) - evaluated with infinite-precision integer arithmetic. */ +#if YYMAXDEPTH == 0 +#undef YYMAXDEPTH +#endif #ifndef YYMAXDEPTH -# define YYMAXDEPTH 10000 +#define YYMAXDEPTH 10000 #endif - +/* Define __yy_memcpy. Note that the size argument + should be passed with type unsigned int, because that is what the non-GCC + definitions require. With GCC, __builtin_memcpy takes an arg + of type size_t, but it can handle unsigned int. */ -#if YYERROR_VERBOSE +#if __GNUC__ > 1 /* GNU C and GNU C++ define this. */ +#define __yy_memcpy(TO,FROM,COUNT) __builtin_memcpy(TO,FROM,COUNT) +#else /* not GNU C or C++ */ +#ifndef __cplusplus -# ifndef yystrlen -# if defined __GLIBC__ && defined _STRING_H -# define yystrlen strlen -# else -/* Return the length of YYSTR. */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static YYSIZE_T -yystrlen (const char *yystr) -#else -static YYSIZE_T -yystrlen (yystr) - const char *yystr; -#endif -{ - YYSIZE_T yylen; - for (yylen = 0; yystr[yylen]; yylen++) - continue; - return yylen; -} -# endif -# endif - -# ifndef yystpcpy -# if defined __GLIBC__ && defined _STRING_H && defined _GNU_SOURCE -# define yystpcpy stpcpy -# else -/* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in - YYDEST. */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -static char * -yystpcpy (char *yydest, const char *yysrc) -#else -static char * -yystpcpy (yydest, yysrc) - char *yydest; - const char *yysrc; -#endif -{ - char *yyd = yydest; - const char *yys = yysrc; - - while ((*yyd++ = *yys++) != '\0') - continue; - - return yyd - 1; -} -# endif -# endif - -# ifndef yytnamerr -/* Copy to YYRES the contents of YYSTR after stripping away unnecessary - quotes and backslashes, so that it's suitable for yyerror. The - heuristic is that double-quoting is unnecessary unless the string - contains an apostrophe, a comma, or backslash (other than - backslash-backslash). YYSTR is taken from yytname. If YYRES is - null, do not copy; instead, return the length of what the result - would have been. */ -static YYSIZE_T -yytnamerr (char *yyres, const char *yystr) -{ - if (*yystr == '"') - { - YYSIZE_T yyn = 0; - char const *yyp = yystr; - - for (;;) - switch (*++yyp) - { - case '\'': - case ',': - goto do_not_strip_quotes; - - case '\\': - if (*++yyp != '\\') - goto do_not_strip_quotes; - /* Fall through. */ - default: - if (yyres) - yyres[yyn] = *yyp; - yyn++; - break; - - case '"': - if (yyres) - yyres[yyn] = '\0'; - return yyn; - } - do_not_strip_quotes: ; - } - - if (! yyres) - return yystrlen (yystr); - - return yystpcpy (yyres, yystr) - yyres; -} -# endif - -/* Copy into YYRESULT an error message about the unexpected token - YYCHAR while in state YYSTATE. Return the number of bytes copied, - including the terminating null byte. If YYRESULT is null, do not - copy anything; just return the number of bytes that would be - copied. As a special case, return 0 if an ordinary "syntax error" - message will do. Return YYSIZE_MAXIMUM if overflow occurs during - size calculation. */ -static YYSIZE_T -yysyntax_error (char *yyresult, int yystate, int yychar) -{ - int yyn = yypact[yystate]; - - if (! (YYPACT_NINF < yyn && yyn <= YYLAST)) - return 0; - else - { - int yytype = YYTRANSLATE (yychar); - YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]); - YYSIZE_T yysize = yysize0; - YYSIZE_T yysize1; - int yysize_overflow = 0; - enum { YYERROR_VERBOSE_ARGS_MAXIMUM = 5 }; - char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; - int yyx; - -# if 0 - /* This is so xgettext sees the translatable formats that are - constructed on the fly. */ - YY_("syntax error, unexpected %s"); - YY_("syntax error, unexpected %s, expecting %s"); - YY_("syntax error, unexpected %s, expecting %s or %s"); - YY_("syntax error, unexpected %s, expecting %s or %s or %s"); - YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); -# endif - char *yyfmt; - char const *yyf; - static char const yyunexpected[] = "syntax error, unexpected %s"; - static char const yyexpecting[] = ", expecting %s"; - static char const yyor[] = " or %s"; - char yyformat[sizeof yyunexpected - + sizeof yyexpecting - 1 - + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) - * (sizeof yyor - 1))]; - char const *yyprefix = yyexpecting; - - /* Start YYX at -YYN if negative to avoid negative indexes in - YYCHECK. */ - int yyxbegin = yyn < 0 ? -yyn : 0; - - /* Stay within bounds of both yycheck and yytname. */ - int yychecklim = YYLAST - yyn + 1; - int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; - int yycount = 1; - - yyarg[0] = yytname[yytype]; - yyfmt = yystpcpy (yyformat, yyunexpected); - - for (yyx = yyxbegin; yyx < yyxend; ++yyx) - if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR) - { - if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) - { - yycount = 1; - yysize = yysize0; - yyformat[sizeof yyunexpected - 1] = '\0'; - break; - } - yyarg[yycount++] = yytname[yyx]; - yysize1 = yysize + yytnamerr (0, yytname[yyx]); - yysize_overflow |= (yysize1 < yysize); - yysize = yysize1; - yyfmt = yystpcpy (yyfmt, yyprefix); - yyprefix = yyor; - } - - yyf = YY_(yyformat); - yysize1 = yysize + yystrlen (yyf); - yysize_overflow |= (yysize1 < yysize); - yysize = yysize1; - - if (yysize_overflow) - return YYSIZE_MAXIMUM; - - if (yyresult) - { - /* Avoid sprintf, as that infringes on the user's name space. - Don't have undefined behavior even if the translation - produced a string with the wrong number of "%s"s. */ - char *yyp = yyresult; - int yyi = 0; - while ((*yyp = *yyf) != '\0') - { - if (*yyp == '%' && yyf[1] == 's' && yyi < yycount) - { - yyp += yytnamerr (yyp, yyarg[yyi++]); - yyf += 2; - } - else - { - yyp++; - yyf++; - } - } - } - return yysize; - } -} -#endif /* YYERROR_VERBOSE */ - - -/*-----------------------------------------------. -| Release the memory associated to this symbol. | -`-----------------------------------------------*/ - -/*ARGSUSED*/ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) +/* This is the most reliable way to avoid incompatibilities + in available built-in functions on various systems. */ static void -yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep) -#else -static void -yydestruct (yymsg, yytype, yyvaluep) - const char *yymsg; - int yytype; - YYSTYPE *yyvaluep; -#endif +__yy_memcpy (to, from, count) + char *to; + char *from; + unsigned int count; { - YYUSE (yyvaluep); + register char *f = from; + register char *t = to; + register int i = count; - if (!yymsg) - yymsg = "Deleting"; - YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp); - - switch (yytype) - { - - default: - break; - } + while (i-- > 0) + *t++ = *f++; } - -/* Prevent warnings from -Wmissing-prototypes. */ +#else /* __cplusplus */ + +/* This is the most reliable way to avoid incompatibilities + in available built-in functions on various systems. */ +static void +__yy_memcpy (char *to, char *from, unsigned int count) +{ + register char *t = to; + register char *f = from; + register int i = count; + + while (i-- > 0) + *t++ = *f++; +} + +#endif +#endif + +#line 217 "/usr/share/bison.simple" + +/* The user can define YYPARSE_PARAM as the name of an argument to be passed + into yyparse. The argument should have type void *. + It should actually point to an object. + Grammar actions can access the variable by casting it + to the proper pointer type. */ #ifdef YYPARSE_PARAM -#if defined __STDC__ || defined __cplusplus -int yyparse (void *YYPARSE_PARAM); +#ifdef __cplusplus +#define YYPARSE_PARAM_ARG void *YYPARSE_PARAM +#define YYPARSE_PARAM_DECL +#else /* not __cplusplus */ +#define YYPARSE_PARAM_ARG YYPARSE_PARAM +#define YYPARSE_PARAM_DECL void *YYPARSE_PARAM; +#endif /* not __cplusplus */ +#else /* not YYPARSE_PARAM */ +#define YYPARSE_PARAM_ARG +#define YYPARSE_PARAM_DECL +#endif /* not YYPARSE_PARAM */ + +/* Prevent warning if -Wstrict-prototypes. */ +#ifdef __GNUC__ +#ifdef YYPARSE_PARAM +int yyparse (void *); #else -int yyparse (); -#endif -#else /* ! YYPARSE_PARAM */ -#if defined __STDC__ || defined __cplusplus int yyparse (void); -#else -int yyparse (); -#endif -#endif /* ! YYPARSE_PARAM */ - - - -/* The look-ahead symbol. */ -int yychar; - -/* The semantic value of the look-ahead symbol. */ -YYSTYPE yylval; - -/* Number of syntax errors so far. */ -int yynerrs; - - - -/*----------. -| yyparse. | -`----------*/ - -#ifdef YYPARSE_PARAM -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -int -yyparse (void *YYPARSE_PARAM) -#else -int -yyparse (YYPARSE_PARAM) - void *YYPARSE_PARAM; -#endif -#else /* ! YYPARSE_PARAM */ -#if (defined __STDC__ || defined __C99__FUNC__ \ - || defined __cplusplus || defined _MSC_VER) -int -yyparse (void) -#else -int -yyparse () - #endif #endif + +int +yyparse(YYPARSE_PARAM_ARG) + YYPARSE_PARAM_DECL { - - int yystate; - int yyn; - int yyresult; - /* Number of tokens to shift before error messages enabled. */ - int yyerrstatus; - /* Look-ahead token as an internal (translated) token number. */ - int yytoken = 0; -#if YYERROR_VERBOSE - /* Buffer for error messages, and its allocated size. */ - char yymsgbuf[128]; - char *yymsg = yymsgbuf; - YYSIZE_T yymsg_alloc = sizeof yymsgbuf; + register int yystate; + register int yyn; + register short *yyssp; + register YYSTYPE *yyvsp; + int yyerrstatus; /* number of tokens to shift before error messages enabled */ + int yychar1 = 0; /* lookahead token as an internal (translated) token number */ + + short yyssa[YYINITDEPTH]; /* the state stack */ + YYSTYPE yyvsa[YYINITDEPTH]; /* the semantic value stack */ + + short *yyss = yyssa; /* refer to the stacks thru separate pointers */ + YYSTYPE *yyvs = yyvsa; /* to allow yyoverflow to reallocate them elsewhere */ + +#ifdef YYLSP_NEEDED + YYLTYPE yylsa[YYINITDEPTH]; /* the location stack */ + YYLTYPE *yyls = yylsa; + YYLTYPE *yylsp; + +#define YYPOPSTACK (yyvsp--, yyssp--, yylsp--) +#else +#define YYPOPSTACK (yyvsp--, yyssp--) #endif - /* Three stacks and their tools: - `yyss': related to states, - `yyvs': related to semantic values, - `yyls': related to locations. + int yystacksize = YYINITDEPTH; + int yyfree_stacks = 0; - Refer to the stacks thru separate pointers, to allow yyoverflow - to reallocate them elsewhere. */ +#ifdef YYPURE + int yychar; + YYSTYPE yylval; + int yynerrs; +#ifdef YYLSP_NEEDED + YYLTYPE yylloc; +#endif +#endif - /* The state stack. */ - yytype_int16 yyssa[YYINITDEPTH]; - yytype_int16 *yyss = yyssa; - yytype_int16 *yyssp; + YYSTYPE yyval; /* the variable used to return */ + /* semantic values from the action */ + /* routines */ - /* The semantic value stack. */ - YYSTYPE yyvsa[YYINITDEPTH]; - YYSTYPE *yyvs = yyvsa; - YYSTYPE *yyvsp; + int yylen; - - -#define YYPOPSTACK(N) (yyvsp -= (N), yyssp -= (N)) - - YYSIZE_T yystacksize = YYINITDEPTH; - - /* The variables used to return semantic value and location from the - action routines. */ - YYSTYPE yyval; - - - /* The number of symbols on the RHS of the reduced rule. - Keep to zero when no symbol should be popped. */ - int yylen = 0; - - YYDPRINTF ((stderr, "Starting parse\n")); +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Starting parse\n"); +#endif yystate = 0; yyerrstatus = 0; @@ -2203,202 +1349,255 @@ yyparse () so that they stay on the same level as the state stack. The wasted elements are never initialized. */ - yyssp = yyss; + yyssp = yyss - 1; yyvsp = yyvs; +#ifdef YYLSP_NEEDED + yylsp = yyls; +#endif - goto yysetstate; +/* Push a new state, which is found in yystate . */ +/* In all cases, when you get here, the value and location stacks + have just been pushed. so pushing a state here evens the stacks. */ +yynewstate: -/*------------------------------------------------------------. -| yynewstate -- Push a new state, which is found in yystate. | -`------------------------------------------------------------*/ - yynewstate: - /* In all cases, when you get here, the value and location stacks - have just been pushed. So pushing a state here evens the stacks. */ - yyssp++; + *++yyssp = yystate; - yysetstate: - *yyssp = yystate; - - if (yyss + yystacksize - 1 <= yyssp) + if (yyssp >= yyss + yystacksize - 1) { + /* Give user a chance to reallocate the stack */ + /* Use copies of these so that the &'s don't force the real ones into memory. */ + YYSTYPE *yyvs1 = yyvs; + short *yyss1 = yyss; +#ifdef YYLSP_NEEDED + YYLTYPE *yyls1 = yyls; +#endif + /* Get the current used size of the three stacks, in elements. */ - YYSIZE_T yysize = yyssp - yyss + 1; + int size = yyssp - yyss + 1; #ifdef yyoverflow - { - /* Give user a chance to reallocate the stack. Use copies of - these so that the &'s don't force the real ones into - memory. */ - YYSTYPE *yyvs1 = yyvs; - yytype_int16 *yyss1 = yyss; + /* Each stack pointer address is followed by the size of + the data in use in that stack, in bytes. */ +#ifdef YYLSP_NEEDED + /* This used to be a conditional around just the two extra args, + but that might be undefined if yyoverflow is a macro. */ + yyoverflow("parser stack overflow", + &yyss1, size * sizeof (*yyssp), + &yyvs1, size * sizeof (*yyvsp), + &yyls1, size * sizeof (*yylsp), + &yystacksize); +#else + yyoverflow("parser stack overflow", + &yyss1, size * sizeof (*yyssp), + &yyvs1, size * sizeof (*yyvsp), + &yystacksize); +#endif - - /* Each stack pointer address is followed by the size of the - data in use in that stack, in bytes. This used to be a - conditional around just the two extra args, but that might - be undefined if yyoverflow is a macro. */ - yyoverflow (YY_("memory exhausted"), - &yyss1, yysize * sizeof (*yyssp), - &yyvs1, yysize * sizeof (*yyvsp), - - &yystacksize); - - yyss = yyss1; - yyvs = yyvs1; - } + yyss = yyss1; yyvs = yyvs1; +#ifdef YYLSP_NEEDED + yyls = yyls1; +#endif #else /* no yyoverflow */ -# ifndef YYSTACK_RELOCATE - goto yyexhaustedlab; -# else /* Extend the stack our own way. */ - if (YYMAXDEPTH <= yystacksize) - goto yyexhaustedlab; + if (yystacksize >= YYMAXDEPTH) + { + yyerror("parser stack overflow"); + if (yyfree_stacks) + { + free (yyss); + free (yyvs); +#ifdef YYLSP_NEEDED + free (yyls); +#endif + } + return 2; + } yystacksize *= 2; - if (YYMAXDEPTH < yystacksize) + if (yystacksize > YYMAXDEPTH) yystacksize = YYMAXDEPTH; - - { - yytype_int16 *yyss1 = yyss; - union yyalloc *yyptr = - (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize)); - if (! yyptr) - goto yyexhaustedlab; - YYSTACK_RELOCATE (yyss); - YYSTACK_RELOCATE (yyvs); - -# undef YYSTACK_RELOCATE - if (yyss1 != yyssa) - YYSTACK_FREE (yyss1); - } -# endif +#ifndef YYSTACK_USE_ALLOCA + yyfree_stacks = 1; +#endif + yyss = (short *) YYSTACK_ALLOC (yystacksize * sizeof (*yyssp)); + __yy_memcpy ((char *)yyss, (char *)yyss1, + size * (unsigned int) sizeof (*yyssp)); + yyvs = (YYSTYPE *) YYSTACK_ALLOC (yystacksize * sizeof (*yyvsp)); + __yy_memcpy ((char *)yyvs, (char *)yyvs1, + size * (unsigned int) sizeof (*yyvsp)); +#ifdef YYLSP_NEEDED + yyls = (YYLTYPE *) YYSTACK_ALLOC (yystacksize * sizeof (*yylsp)); + __yy_memcpy ((char *)yyls, (char *)yyls1, + size * (unsigned int) sizeof (*yylsp)); +#endif #endif /* no yyoverflow */ - yyssp = yyss + yysize - 1; - yyvsp = yyvs + yysize - 1; + yyssp = yyss + size - 1; + yyvsp = yyvs + size - 1; +#ifdef YYLSP_NEEDED + yylsp = yyls + size - 1; +#endif +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Stack size increased to %d\n", yystacksize); +#endif - YYDPRINTF ((stderr, "Stack size increased to %lu\n", - (unsigned long int) yystacksize)); - - if (yyss + yystacksize - 1 <= yyssp) + if (yyssp >= yyss + yystacksize - 1) YYABORT; } - YYDPRINTF ((stderr, "Entering state %d\n", yystate)); +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Entering state %d\n", yystate); +#endif goto yybackup; + yybackup: -/*-----------. -| yybackup. | -`-----------*/ -yybackup: +/* Do appropriate processing given the current state. */ +/* Read a lookahead token if we need one and don't already have one. */ +/* yyresume: */ - /* Do appropriate processing given the current state. Read a - look-ahead token if we need one and don't already have one. */ + /* First try to decide what to do without reference to lookahead token. */ - /* First try to decide what to do without reference to look-ahead token. */ yyn = yypact[yystate]; - if (yyn == YYPACT_NINF) + if (yyn == YYFLAG) goto yydefault; - /* Not known => get a look-ahead token if don't already have one. */ + /* Not known => get a lookahead token if don't already have one. */ + + /* yychar is either YYEMPTY or YYEOF + or a valid token in external form. */ - /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol. */ if (yychar == YYEMPTY) { - YYDPRINTF ((stderr, "Reading a token: ")); +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Reading a token: "); +#endif yychar = YYLEX; } - if (yychar <= YYEOF) + /* Convert token to internal form (in yychar1) for indexing tables with */ + + if (yychar <= 0) /* This means end of input. */ { - yychar = yytoken = YYEOF; - YYDPRINTF ((stderr, "Now at end of input.\n")); + yychar1 = 0; + yychar = YYEOF; /* Don't call YYLEX any more */ + +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Now at end of input.\n"); +#endif } else { - yytoken = YYTRANSLATE (yychar); - YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc); + yychar1 = YYTRANSLATE(yychar); + +#if YYDEBUG != 0 + if (yydebug) + { + fprintf (stderr, "Next token is %d (%s", yychar, yytname[yychar1]); + /* Give the individual parser a way to print the precise meaning + of a token, for further debugging info. */ +#ifdef YYPRINT + YYPRINT (stderr, yychar, yylval); +#endif + fprintf (stderr, ")\n"); + } +#endif } - /* If the proper action on seeing token YYTOKEN is to reduce or to - detect an error, take that action. */ - yyn += yytoken; - if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken) + yyn += yychar1; + if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1) goto yydefault; + yyn = yytable[yyn]; - if (yyn <= 0) + + /* yyn is what to do for this token type in this state. + Negative => reduce, -yyn is rule number. + Positive => shift, yyn is new state. + New state is final state => don't bother to shift, + just return success. + 0, or most negative number => error. */ + + if (yyn < 0) { - if (yyn == 0 || yyn == YYTABLE_NINF) + if (yyn == YYFLAG) goto yyerrlab; yyn = -yyn; goto yyreduce; } + else if (yyn == 0) + goto yyerrlab; if (yyn == YYFINAL) YYACCEPT; - /* Count tokens shifted since error; after three, turn off error - status. */ - if (yyerrstatus) - yyerrstatus--; + /* Shift the lookahead token. */ - /* Shift the look-ahead token. */ - YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc); +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]); +#endif - /* Discard the shifted token unless it is eof. */ + /* Discard the token being shifted unless it is eof. */ if (yychar != YYEOF) yychar = YYEMPTY; - yystate = yyn; *++yyvsp = yylval; +#ifdef YYLSP_NEEDED + *++yylsp = yylloc; +#endif + /* count tokens shifted since error; after three, turn off error status. */ + if (yyerrstatus) yyerrstatus--; + + yystate = yyn; goto yynewstate; - -/*-----------------------------------------------------------. -| yydefault -- do the default action for the current state. | -`-----------------------------------------------------------*/ +/* Do the default action for the current state. */ yydefault: + yyn = yydefact[yystate]; if (yyn == 0) goto yyerrlab; - goto yyreduce; - -/*-----------------------------. -| yyreduce -- Do a reduction. | -`-----------------------------*/ +/* Do a reduction. yyn is the number of a rule to reduce with. */ yyreduce: - /* yyn is the number of a rule to reduce with. */ yylen = yyr2[yyn]; + if (yylen > 0) + yyval = yyvsp[1-yylen]; /* implement default value of the action */ - /* If YYLEN is nonzero, implement the default value of the action: - `$$ = $1'. - - Otherwise, the following line sets YYVAL to garbage. - This behavior is undocumented and Bison - users should not rely upon it. Assigning to YYVAL - unconditionally makes the parser a bit smaller, and it avoids a - GCC warning that YYVAL may be used uninitialized. */ - yyval = yyvsp[1-yylen]; - - - YY_REDUCE_PRINT (yyn); - switch (yyn) - { - case 7: -#line 232 "parser.yxx" +#if YYDEBUG != 0 + if (yydebug) { + int i; + + fprintf (stderr, "Reducing via rule %d (line %d), ", + yyn, yyrline[yyn]); + + /* Print the symbols being reduced, and their result. */ + for (i = yyprhs[yyn]; yyrhs[i] > 0; i++) + fprintf (stderr, "%s ", yytname[yyrhs[i]]); + fprintf (stderr, " -> %s\n", yytname[yyr1[yyn]]); + } +#endif + + + switch (yyn) { + +case 6: +#line 235 "parser.yxx" +{ assert(!egg_stack.empty()); - DCAST(EggData, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 25: -#line 275 "parser.yxx" - { - string strval = (yyvsp[(3) - (4)]._string); + DCAST(EggData, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 25: +#line 279 "parser.yxx" +{ + string strval = yyvsp[-1]._string; EggCoordinateSystem *cs = new EggCoordinateSystem; CoordinateSystem f = parse_coordinate_system_string(strval); @@ -2407,22 +1606,20 @@ yyreduce: } else { cs->set_value(f); } - (yyval._egg) = cs; -} - break; - - case 26: -#line 298 "parser.yxx" - { - (yyval._egg) = new EggComment((yyvsp[(2) - (5)]._string), (yyvsp[(4) - (5)]._string)); -} - break; - - case 27: -#line 312 "parser.yxx" - { - string tref_name = (yyvsp[(2) - (4)]._string); - Filename filename = (yyvsp[(4) - (4)]._string); + yyval._egg = cs; +; + break;} +case 26: +#line 302 "parser.yxx" +{ + yyval._egg = new EggComment(yyvsp[-3]._string, yyvsp[-1]._string); +; + break;} +case 27: +#line 316 "parser.yxx" +{ + string tref_name = yyvsp[-2]._string; + Filename filename = yyvsp[0]._string; EggTexture *texture = new EggTexture(tref_name, filename); if (textures.find(tref_name) != textures.end()) { @@ -2431,24 +1628,22 @@ yyreduce: textures[tref_name] = texture; egg_stack.push_back(texture); -} - break; - - case 28: -#line 325 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 28: +#line 329 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 30: -#line 341 "parser.yxx" - { +; + break;} +case 30: +#line 345 "parser.yxx" +{ EggTexture *texture = DCAST(EggTexture, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "type") == 0) { EggTexture::TextureType tt = EggTexture::string_texture_type(strval); @@ -2643,11 +1838,19 @@ yyreduce: } else if (cmp_nocase_uh(name, "tex_gen") == 0) { EggTexture::TexGen tex_gen = EggTexture::string_tex_gen(strval); if (tex_gen == EggTexture::TG_unspecified) { - eggyywarning("Unknown texture env type " + strval); + eggyywarning("Unknown tex-gen " + strval); } else { texture->set_tex_gen(tex_gen); } + } else if (cmp_nocase_uh(name, "quality_level") == 0) { + EggTexture::QualityLevel quality_level = EggTexture::string_quality_level(strval); + if (quality_level == EggTexture::QL_unspecified) { + eggyywarning("Unknown quality-level " + strval); + } else { + texture->set_quality_level(quality_level); + } + } else if (cmp_nocase_uh(name, "stage_name") == 0) { texture->set_stage_name(strval); @@ -2766,13 +1969,12 @@ yyreduce: } else { eggyywarning("Unsupported texture scalar: " + name); } -} - break; - - case 32: -#line 676 "parser.yxx" - { - string mref_name = (yyvsp[(2) - (3)]._string); +; + break;} +case 32: +#line 688 "parser.yxx" +{ + string mref_name = yyvsp[-1]._string; EggMaterial *material = new EggMaterial(mref_name); if (materials.find(mref_name) != materials.end()) { @@ -2781,23 +1983,21 @@ yyreduce: materials[mref_name] = material; egg_stack.push_back(material); -} - break; - - case 33: -#line 688 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 33: +#line 700 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 35: -#line 704 "parser.yxx" - { +; + break;} +case 35: +#line 716 "parser.yxx" +{ EggMaterial *material = DCAST(EggMaterial, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; if (cmp_nocase_uh(name, "diffr") == 0) { Colorf diff = material->get_diff(); @@ -2876,36 +2076,33 @@ yyreduce: } else { eggyywarning("Unsupported material scalar: " + name); } -} - break; - - case 36: -#line 799 "parser.yxx" - { - string node_name = (yyvsp[(2) - (5)]._string); - Filename filename = (yyvsp[(4) - (5)]._string); +; + break;} +case 36: +#line 811 "parser.yxx" +{ + string node_name = yyvsp[-3]._string; + Filename filename = yyvsp[-1]._string; EggExternalReference *ref = new EggExternalReference(node_name, filename); - (yyval._egg) = ref; -} - break; - - case 37: -#line 806 "parser.yxx" - { - if (cmp_nocase_uh((yyvsp[(1) - (6)]._string), "group") != 0) { + yyval._egg = ref; +; + break;} +case 37: +#line 818 "parser.yxx" +{ + if (cmp_nocase_uh(yyvsp[-5]._string, "group") != 0) { eggyyerror("keyword 'group' expected"); } - string node_name = (yyvsp[(3) - (6)]._string); - Filename filename = (yyvsp[(5) - (6)]._string); + string node_name = yyvsp[-3]._string; + Filename filename = yyvsp[-1]._string; EggExternalReference *ref = new EggExternalReference(node_name, filename); - (yyval._egg) = ref; -} - break; - - case 38: -#line 826 "parser.yxx" - { - string name = (yyvsp[(2) - (2)]._string); + yyval._egg = ref; +; + break;} +case 38: +#line 838 "parser.yxx" +{ + string name = yyvsp[0]._string; EggVertexPool *pool = NULL; VertexPools::const_iterator vpi = vertex_pools.find(name); @@ -2926,38 +2123,34 @@ yyreduce: } egg_stack.push_back(pool); -} - break; - - case 39: -#line 850 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 39: +#line 862 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 42: -#line 878 "parser.yxx" - { +; + break;} +case 42: +#line 890 "parser.yxx" +{ egg_stack.push_back(new EggVertex); -} - break; - - case 43: -#line 882 "parser.yxx" - { +; + break;} +case 43: +#line 894 "parser.yxx" +{ PT(EggVertex) vtx = DCAST(EggVertex, egg_stack.back()); egg_stack.pop_back(); DCAST(EggVertexPool, egg_stack.back())->add_vertex(vtx); -} - break; - - case 44: -#line 889 "parser.yxx" - { - vertex_index = (int)(yyvsp[(2) - (2)]._number); +; + break;} +case 44: +#line 901 "parser.yxx" +{ + vertex_index = (int)yyvsp[0]._number; EggVertexPool *pool = DCAST(EggVertexPool, egg_stack.back()); if (vertex_index < 0) { @@ -2979,12 +2172,11 @@ yyreduce: // go ahead and parse the vertex. We just won't save it. egg_stack.push_back(new EggVertex); -} - break; - - case 45: -#line 914 "parser.yxx" - { +; + break;} +case 45: +#line 926 "parser.yxx" +{ PT(EggVertex) vtx = DCAST(EggVertex, egg_stack.back()); egg_stack.pop_back(); @@ -2992,276 +2184,247 @@ yyreduce: if (vertex_index != -1) { pool->add_vertex(vtx, vertex_index); } -} - break; - - case 46: -#line 935 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_pos((yyvsp[(1) - (1)]._number)); -} - break; - - case 47: -#line 939 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_pos(LPoint2d((yyvsp[(1) - (2)]._number), (yyvsp[(2) - (2)]._number))); -} - break; - - case 48: -#line 943 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_pos(LPoint3d((yyvsp[(1) - (3)]._number), (yyvsp[(2) - (3)]._number), (yyvsp[(3) - (3)]._number))); -} - break; - - case 49: +; + break;} +case 46: #line 947 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_pos(LPoint4d((yyvsp[(1) - (4)]._number), (yyvsp[(2) - (4)]._number), (yyvsp[(3) - (4)]._number), (yyvsp[(4) - (4)]._number))); -} - break; - - case 50: +{ + DCAST(EggVertex, egg_stack.back())->set_pos(yyvsp[0]._number); +; + break;} +case 47: #line 951 "parser.yxx" - { +{ + DCAST(EggVertex, egg_stack.back())->set_pos(LPoint2d(yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 48: +#line 955 "parser.yxx" +{ + DCAST(EggVertex, egg_stack.back())->set_pos(LPoint3d(yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 49: +#line 959 "parser.yxx" +{ + DCAST(EggVertex, egg_stack.back())->set_pos(LPoint4d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 50: +#line 963 "parser.yxx" +{ EggVertex *vertex = DCAST(EggVertex, egg_stack.back()); - EggVertexUV *uv = new EggVertexUV((yyvsp[(3) - (4)]._string), TexCoordd::zero()); + EggVertexUV *uv = new EggVertexUV(yyvsp[-1]._string, TexCoordd::zero()); egg_stack.push_back(uv); - if (vertex->has_uv((yyvsp[(3) - (4)]._string))) { - eggyywarning("Ignoring repeated UV name " + (yyvsp[(3) - (4)]._string)); + if (vertex->has_uv(yyvsp[-1]._string)) { + eggyywarning("Ignoring repeated UV name " + yyvsp[-1]._string); } else { vertex->set_uv_obj(uv); } -} - break; - - case 51: -#line 962 "parser.yxx" - { +; + break;} +case 51: +#line 974 "parser.yxx" +{ egg_stack.pop_back(); -} - break; - - case 54: -#line 968 "parser.yxx" - { +; + break;} +case 54: +#line 980 "parser.yxx" +{ bool inserted = DCAST(EggVertex, egg_stack.back())->_dxyzs. - insert(EggMorphVertex((yyvsp[(3) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphVertex(yyvsp[-5]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); } -} - break; - - case 55: -#line 976 "parser.yxx" - { +; + break;} +case 55: +#line 988 "parser.yxx" +{ bool inserted = DCAST(EggVertex, egg_stack.back())->_dxyzs. - insert(EggMorphVertex((yyvsp[(4) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphVertex(yyvsp[-4]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-4]._string); } -} - break; - - case 56: -#line 995 "parser.yxx" - { - DCAST(EggVertexUV, egg_stack.back())->set_uv(TexCoordd((yyvsp[(1) - (2)]._number), (yyvsp[(2) - (2)]._number))); -} - break; - - case 57: -#line 999 "parser.yxx" - { - DCAST(EggVertexUV, egg_stack.back())->set_uvw(LVecBase3d((yyvsp[(1) - (3)]._number), (yyvsp[(2) - (3)]._number), (yyvsp[(3) - (3)]._number))); -} - break; - - case 58: -#line 1003 "parser.yxx" - { +; + break;} +case 56: +#line 1007 "parser.yxx" +{ + DCAST(EggVertexUV, egg_stack.back())->set_uv(TexCoordd(yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 57: +#line 1011 "parser.yxx" +{ + DCAST(EggVertexUV, egg_stack.back())->set_uvw(LVecBase3d(yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 58: +#line 1015 "parser.yxx" +{ if (DCAST(EggVertexUV, egg_stack.back())->has_tangent()) { eggyywarning("Ignoring repeated tangent"); } else { - DCAST(EggVertexUV, egg_stack.back())->set_tangent(Normald((yyvsp[(4) - (7)]._number), (yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number))); + DCAST(EggVertexUV, egg_stack.back())->set_tangent(Normald(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); } -} - break; - - case 59: -#line 1011 "parser.yxx" - { +; + break;} +case 59: +#line 1023 "parser.yxx" +{ if (DCAST(EggVertexUV, egg_stack.back())->has_binormal()) { eggyywarning("Ignoring repeated binormal"); } else { - DCAST(EggVertexUV, egg_stack.back())->set_binormal(Normald((yyvsp[(4) - (7)]._number), (yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number))); + DCAST(EggVertexUV, egg_stack.back())->set_binormal(Normald(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); } -} - break; - - case 60: -#line 1019 "parser.yxx" - { +; + break;} +case 60: +#line 1031 "parser.yxx" +{ bool inserted = DCAST(EggVertexUV, egg_stack.back())->_duvs. - insert(EggMorphTexCoord((yyvsp[(3) - (7)]._string), LVector3d((yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number), 0.0))).second; + insert(EggMorphTexCoord(yyvsp[-4]._string, LVector3d(yyvsp[-2]._number, yyvsp[-1]._number, 0.0))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (7)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-4]._string); } -} - break; - - case 61: -#line 1027 "parser.yxx" - { +; + break;} +case 61: +#line 1039 "parser.yxx" +{ bool inserted = DCAST(EggVertexUV, egg_stack.back())->_duvs. - insert(EggMorphTexCoord((yyvsp[(3) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphTexCoord(yyvsp[-5]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); } -} - break; - - case 62: -#line 1035 "parser.yxx" - { +; + break;} +case 62: +#line 1047 "parser.yxx" +{ bool inserted = DCAST(EggVertexUV, egg_stack.back())->_duvs. - insert(EggMorphTexCoord((yyvsp[(4) - (7)]._string), LVector3d((yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number), 0.0))).second; + insert(EggMorphTexCoord(yyvsp[-3]._string, LVector3d(yyvsp[-2]._number, yyvsp[-1]._number, 0.0))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (7)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-3]._string); } -} - break; - - case 63: -#line 1043 "parser.yxx" - { +; + break;} +case 63: +#line 1055 "parser.yxx" +{ bool inserted = DCAST(EggVertexUV, egg_stack.back())->_duvs. - insert(EggMorphTexCoord((yyvsp[(4) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphTexCoord(yyvsp[-4]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-4]._string); } -} - break; - - case 64: -#line 1061 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_normal(Normald((yyvsp[(1) - (3)]._number), (yyvsp[(2) - (3)]._number), (yyvsp[(3) - (3)]._number))); -} - break; - - case 65: -#line 1065 "parser.yxx" - { - bool inserted = DCAST(EggVertex, egg_stack.back())->_dnormals. - insert(EggMorphNormal((yyvsp[(3) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; - if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (8)]._string)); - } -} - break; - - case 66: +; + break;} +case 64: #line 1073 "parser.yxx" - { +{ + DCAST(EggVertex, egg_stack.back())->set_normal(Normald(yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 65: +#line 1077 "parser.yxx" +{ bool inserted = DCAST(EggVertex, egg_stack.back())->_dnormals. - insert(EggMorphNormal((yyvsp[(4) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphNormal(yyvsp[-5]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); } -} - break; - - case 67: -#line 1091 "parser.yxx" - { - DCAST(EggVertex, egg_stack.back())->set_color(Colorf((yyvsp[(1) - (4)]._number), (yyvsp[(2) - (4)]._number), (yyvsp[(3) - (4)]._number), (yyvsp[(4) - (4)]._number))); -} - break; - - case 68: -#line 1095 "parser.yxx" - { - bool inserted = DCAST(EggVertex, egg_stack.back())->_drgbas. - insert(EggMorphColor((yyvsp[(3) - (9)]._string), LVector4f((yyvsp[(5) - (9)]._number), (yyvsp[(6) - (9)]._number), (yyvsp[(7) - (9)]._number), (yyvsp[(8) - (9)]._number)))).second; +; + break;} +case 66: +#line 1085 "parser.yxx" +{ + bool inserted = DCAST(EggVertex, egg_stack.back())->_dnormals. + insert(EggMorphNormal(yyvsp[-4]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (9)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-4]._string); } -} - break; - - case 69: +; + break;} +case 67: #line 1103 "parser.yxx" - { +{ + DCAST(EggVertex, egg_stack.back())->set_color(Colorf(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 68: +#line 1107 "parser.yxx" +{ bool inserted = DCAST(EggVertex, egg_stack.back())->_drgbas. - insert(EggMorphColor((yyvsp[(4) - (9)]._string), LVector4f((yyvsp[(5) - (9)]._number), (yyvsp[(6) - (9)]._number), (yyvsp[(7) - (9)]._number), (yyvsp[(8) - (9)]._number)))).second; + insert(EggMorphColor(yyvsp[-6]._string, LVector4f(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (9)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-6]._string); } -} - break; - - case 70: -#line 1121 "parser.yxx" - { - EggGroup *group = new EggGroup((yyvsp[(2) - (2)]._string)); +; + break;} +case 69: +#line 1115 "parser.yxx" +{ + bool inserted = DCAST(EggVertex, egg_stack.back())->_drgbas. + insert(EggMorphColor(yyvsp[-5]._string, LVector4f(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; + if (!inserted) { + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); + } +; + break;} +case 70: +#line 1133 "parser.yxx" +{ + EggGroup *group = new EggGroup(yyvsp[0]._string); egg_stack.push_back(group); -} - break; - - case 71: -#line 1126 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 71: +#line 1138 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 72: -#line 1141 "parser.yxx" - { - EggGroup *group = new EggGroup((yyvsp[(2) - (2)]._string)); +; + break;} +case 72: +#line 1153 "parser.yxx" +{ + EggGroup *group = new EggGroup(yyvsp[0]._string); group->set_group_type(EggGroup::GT_joint); egg_stack.push_back(group); -} - break; - - case 73: -#line 1147 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 73: +#line 1159 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 74: -#line 1162 "parser.yxx" - { - EggGroup *group = new EggGroup((yyvsp[(2) - (2)]._string)); +; + break;} +case 74: +#line 1174 "parser.yxx" +{ + EggGroup *group = new EggGroup(yyvsp[0]._string); group->set_group_type(EggGroup::GT_instance); egg_stack.push_back(group); -} - break; - - case 75: -#line 1168 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 75: +#line 1180 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 77: -#line 1184 "parser.yxx" - { +; + break;} +case 77: +#line 1196 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - unsigned long ulong_value = (yyvsp[(5) - (6)]._ulong); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + unsigned long ulong_value = yyvsp[-1]._ulong; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "fps") == 0) { group->set_switch_fps(value); @@ -3384,14 +2547,13 @@ yyreduce: } else { eggyywarning("Unknown group scalar " + name); } -} - break; - - case 78: -#line 1314 "parser.yxx" - { +; + break;} +case 78: +#line 1326 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string strval = (yyvsp[(4) - (5)]._string); + string strval = yyvsp[-1]._string; EggGroup::BillboardType f = EggGroup::string_billboard_type(strval); if (f == EggGroup::BT_none) { @@ -3399,42 +2561,38 @@ yyreduce: } else { group->set_billboard_type(f); } -} - break; - - case 79: -#line 1326 "parser.yxx" - { +; + break;} +case 79: +#line 1338 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - group->set_billboard_center(LPoint3d((yyvsp[(4) - (7)]._number), (yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number))); -} - break; - - case 80: -#line 1331 "parser.yxx" - { + group->set_billboard_center(LPoint3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 80: +#line 1343 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string name = (yyvsp[(3) - (7)]._string); + string name = yyvsp[-4]._string; group->set_collision_name(name); -} - break; - - case 81: -#line 1338 "parser.yxx" - { +; + break;} +case 81: +#line 1350 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - int value = (int)(yyvsp[(4) - (5)]._number); + int value = (int)yyvsp[-1]._number; group->set_dcs_type(value!=0 ? EggGroup::DC_default : EggGroup::DC_none); -} - break; - - case 82: -#line 1344 "parser.yxx" - { +; + break;} +case 82: +#line 1356 "parser.yxx" +{ // The special flavor of DCS, with { sync } or { nosync }. EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string strval = (yyvsp[(4) - (5)]._string); + string strval = yyvsp[-1]._string; EggGroup::DCSType f = EggGroup::string_dcs_type(strval); if (f == EggGroup::DC_unspecified) { @@ -3442,25 +2600,23 @@ yyreduce: } else { group->set_dcs_type(f); } -} - break; - - case 83: -#line 1357 "parser.yxx" - { +; + break;} +case 83: +#line 1369 "parser.yxx" +{ // The traditional flavor of DART, with { 0 } or { 1 }. EggGroup *group = DCAST(EggGroup, egg_stack.back()); - int value = (int)(yyvsp[(4) - (5)]._number); + int value = (int)yyvsp[-1]._number; group->set_dart_type(value!=0 ? EggGroup::DT_default : EggGroup::DT_none); -} - break; - - case 84: -#line 1364 "parser.yxx" - { +; + break;} +case 84: +#line 1376 "parser.yxx" +{ // The special flavor of DART, with { sync } or { nosync }. EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string strval = (yyvsp[(4) - (5)]._string); + string strval = yyvsp[-1]._string; EggGroup::DartType f = EggGroup::string_dart_type(strval); if (f == EggGroup::DT_none) { @@ -3468,65 +2624,58 @@ yyreduce: } else { group->set_dart_type(f); } -} - break; - - case 85: -#line 1377 "parser.yxx" - { - EggGroup *group = DCAST(EggGroup, egg_stack.back()); - int value = (int)(yyvsp[(4) - (5)]._number); - group->set_switch_flag(value!=0); -} - break; - - case 86: -#line 1383 "parser.yxx" - { - EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string type = (yyvsp[(4) - (5)]._string); - group->add_object_type(type); -} - break; - - case 87: +; + break;} +case 85: #line 1389 "parser.yxx" - { +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - int value = (int)(yyvsp[(4) - (5)]._number); - group->set_model_flag(value!=0); -} - break; - - case 88: + int value = (int)yyvsp[-1]._number; + group->set_switch_flag(value!=0); +; + break;} +case 86: #line 1395 "parser.yxx" - { +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - group->set_tag((yyvsp[(3) - (6)]._string), (yyvsp[(5) - (6)]._string)); -} - break; - - case 89: -#line 1400 "parser.yxx" - { + string type = yyvsp[-1]._string; + group->add_object_type(type); +; + break;} +case 87: +#line 1401 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - int value = (int)(yyvsp[(4) - (5)]._number); + int value = (int)yyvsp[-1]._number; + group->set_model_flag(value!=0); +; + break;} +case 88: +#line 1407 "parser.yxx" +{ + EggGroup *group = DCAST(EggGroup, egg_stack.back()); + group->set_tag(yyvsp[-3]._string, yyvsp[-1]._string); +; + break;} +case 89: +#line 1412 "parser.yxx" +{ + EggGroup *group = DCAST(EggGroup, egg_stack.back()); + int value = (int)yyvsp[-1]._number; group->set_texlist_flag(value!=0); -} - break; - - case 93: -#line 1409 "parser.yxx" - { - DCAST(EggGroup, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 94: -#line 1423 "parser.yxx" - { +; + break;} +case 93: +#line 1421 "parser.yxx" +{ + DCAST(EggGroup, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 94: +#line 1435 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string strval = (yyvsp[(1) - (1)]._string); + string strval = yyvsp[0]._string; EggGroup::CollisionSolidType f = EggGroup::string_cs_type(strval); if (f == EggGroup::CST_none) { @@ -3542,14 +2691,13 @@ yyreduce: group->set_cs_type(f); } } -} - break; - - case 96: -#line 1454 "parser.yxx" - { +; + break;} +case 96: +#line 1466 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - string strval = (yyvsp[(2) - (2)]._string); + string strval = yyvsp[0]._string; EggGroup::CollideFlags f = EggGroup::string_collide_flags(strval); if (f == EggGroup::CF_none) { @@ -3557,115 +2705,101 @@ yyreduce: } else { group->set_collide_flags(group->get_collide_flags() | f); } -} - break; - - case 97: -#line 1476 "parser.yxx" - { +; + break;} +case 97: +#line 1488 "parser.yxx" +{ egg_stack.back()->as_transform()->clear_transform(); -} - break; - - case 112: -#line 1508 "parser.yxx" - { - egg_stack.back()->as_transform()->add_translate2d(LVector2d((yyvsp[(3) - (5)]._number), (yyvsp[(4) - (5)]._number))); -} - break; - - case 113: -#line 1515 "parser.yxx" - { - egg_stack.back()->as_transform()->add_translate3d(LVector3d((yyvsp[(3) - (6)]._number), (yyvsp[(4) - (6)]._number), (yyvsp[(5) - (6)]._number))); -} - break; - - case 114: -#line 1522 "parser.yxx" - { - egg_stack.back()->as_transform()->add_rotate2d((yyvsp[(3) - (4)]._number)); -} - break; - - case 115: -#line 1529 "parser.yxx" - { - egg_stack.back()->as_transform()->add_rotx((yyvsp[(3) - (4)]._number)); -} - break; - - case 116: -#line 1536 "parser.yxx" - { - egg_stack.back()->as_transform()->add_roty((yyvsp[(3) - (4)]._number)); -} - break; - - case 117: -#line 1543 "parser.yxx" - { - egg_stack.back()->as_transform()->add_rotz((yyvsp[(3) - (4)]._number)); -} - break; - - case 118: -#line 1550 "parser.yxx" - { - egg_stack.back()->as_transform()->add_rotate3d((yyvsp[(3) - (7)]._number), LVector3d((yyvsp[(4) - (7)]._number), (yyvsp[(5) - (7)]._number), (yyvsp[(6) - (7)]._number))); -} - break; - - case 119: -#line 1557 "parser.yxx" - { - egg_stack.back()->as_transform()->add_scale2d(LVecBase2d((yyvsp[(3) - (5)]._number), (yyvsp[(4) - (5)]._number))); -} - break; - - case 120: -#line 1564 "parser.yxx" - { - egg_stack.back()->as_transform()->add_scale3d(LVecBase3d((yyvsp[(3) - (6)]._number), (yyvsp[(4) - (6)]._number), (yyvsp[(5) - (6)]._number))); -} - break; - - case 121: -#line 1571 "parser.yxx" - { - egg_stack.back()->as_transform()->add_uniform_scale((yyvsp[(3) - (4)]._number)); -} - break; - - case 124: -#line 1585 "parser.yxx" - { +; + break;} +case 112: +#line 1520 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_translate2d(LVector2d(yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 113: +#line 1527 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_translate3d(LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 114: +#line 1534 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_rotate2d(yyvsp[-1]._number); +; + break;} +case 115: +#line 1541 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_rotx(yyvsp[-1]._number); +; + break;} +case 116: +#line 1548 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_roty(yyvsp[-1]._number); +; + break;} +case 117: +#line 1555 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_rotz(yyvsp[-1]._number); +; + break;} +case 118: +#line 1562 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_rotate3d(yyvsp[-4]._number, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 119: +#line 1569 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_scale2d(LVecBase2d(yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 120: +#line 1576 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_scale3d(LVecBase3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number)); +; + break;} +case 121: +#line 1583 "parser.yxx" +{ + egg_stack.back()->as_transform()->add_uniform_scale(yyvsp[-1]._number); +; + break;} +case 124: +#line 1597 "parser.yxx" +{ egg_stack.back()->as_transform()->add_matrix3 - (LMatrix3d((yyvsp[(1) - (9)]._number), (yyvsp[(2) - (9)]._number), (yyvsp[(3) - (9)]._number), - (yyvsp[(4) - (9)]._number), (yyvsp[(5) - (9)]._number), (yyvsp[(6) - (9)]._number), - (yyvsp[(7) - (9)]._number), (yyvsp[(8) - (9)]._number), (yyvsp[(9) - (9)]._number))); -} - break; - - case 127: -#line 1603 "parser.yxx" - { + (LMatrix3d(yyvsp[-8]._number, yyvsp[-7]._number, yyvsp[-6]._number, + yyvsp[-5]._number, yyvsp[-4]._number, yyvsp[-3]._number, + yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 127: +#line 1615 "parser.yxx" +{ egg_stack.back()->as_transform()->add_matrix4 - (LMatrix4d((yyvsp[(1) - (16)]._number), (yyvsp[(2) - (16)]._number), (yyvsp[(3) - (16)]._number), (yyvsp[(4) - (16)]._number), - (yyvsp[(5) - (16)]._number), (yyvsp[(6) - (16)]._number), (yyvsp[(7) - (16)]._number), (yyvsp[(8) - (16)]._number), - (yyvsp[(9) - (16)]._number), (yyvsp[(10) - (16)]._number), (yyvsp[(11) - (16)]._number), (yyvsp[(12) - (16)]._number), - (yyvsp[(13) - (16)]._number), (yyvsp[(14) - (16)]._number), (yyvsp[(15) - (16)]._number), (yyvsp[(16) - (16)]._number))); -} - break; - - case 128: -#line 1622 "parser.yxx" - { - if ((yyvsp[(7) - (9)]._egg) != (EggVertexPool *)NULL) { - EggVertexPool *pool = DCAST(EggVertexPool, (yyvsp[(7) - (9)]._egg)); + (LMatrix4d(yyvsp[-15]._number, yyvsp[-14]._number, yyvsp[-13]._number, yyvsp[-12]._number, + yyvsp[-11]._number, yyvsp[-10]._number, yyvsp[-9]._number, yyvsp[-8]._number, + yyvsp[-7]._number, yyvsp[-6]._number, yyvsp[-5]._number, yyvsp[-4]._number, + yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 128: +#line 1634 "parser.yxx" +{ + if (yyvsp[-2]._egg != (EggVertexPool *)NULL) { + EggVertexPool *pool = DCAST(EggVertexPool, yyvsp[-2]._egg); EggGroup *group = DCAST(EggGroup, egg_stack.back()); - PTA_double nums = (yyvsp[(3) - (9)]._number_list); - double membership = (yyvsp[(4) - (9)]._number); + PTA_double nums = yyvsp[-6]._number_list; + double membership = yyvsp[-5]._number; for (int i = 0; i < (int)nums.size(); i++) { int index = (int)nums[i]; @@ -3680,22 +2814,20 @@ yyreduce: } } } -} - break; - - case 129: -#line 1655 "parser.yxx" - { - (yyval._number) = 1.0; -} - break; - - case 130: -#line 1659 "parser.yxx" - { - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - double result = (yyvsp[(1) - (6)]._number); +; + break;} +case 129: +#line 1667 "parser.yxx" +{ + yyval._number = 1.0; +; + break;} +case 130: +#line 1671 "parser.yxx" +{ + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + double result = yyvsp[-5]._number; if (cmp_nocase_uh(name, "membership") == 0) { result = value; @@ -3703,165 +2835,146 @@ yyreduce: eggyywarning("Unknown group vertex scalar " + name); } - (yyval._number) = result; -} - break; - - case 132: -#line 1696 "parser.yxx" - { + yyval._number = result; +; + break;} +case 132: +#line 1708 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - group->set_lod(EggSwitchConditionDistance((yyvsp[(3) - (11)]._number), (yyvsp[(4) - (11)]._number), LPoint3d((yyvsp[(7) - (11)]._number), (yyvsp[(8) - (11)]._number), (yyvsp[(9) - (11)]._number)))); -} - break; - - case 133: -#line 1701 "parser.yxx" - { + group->set_lod(EggSwitchConditionDistance(yyvsp[-8]._number, yyvsp[-7]._number, LPoint3d(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number))); +; + break;} +case 133: +#line 1713 "parser.yxx" +{ EggGroup *group = DCAST(EggGroup, egg_stack.back()); - group->set_lod(EggSwitchConditionDistance((yyvsp[(3) - (12)]._number), (yyvsp[(4) - (12)]._number), LPoint3d((yyvsp[(8) - (12)]._number), (yyvsp[(9) - (12)]._number), (yyvsp[(10) - (12)]._number)), (yyvsp[(5) - (12)]._number))); -} - break; - - case 134: -#line 1718 "parser.yxx" - { - egg_stack.push_back(new EggPolygon((yyvsp[(2) - (2)]._string))); -} - break; - - case 135: -#line 1722 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); + group->set_lod(EggSwitchConditionDistance(yyvsp[-9]._number, yyvsp[-8]._number, LPoint3d(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number), yyvsp[-7]._number)); +; + break;} +case 134: +#line 1730 "parser.yxx" +{ + egg_stack.push_back(new EggPolygon(yyvsp[0]._string)); +; + break;} +case 135: +#line 1734 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 136: -#line 1737 "parser.yxx" - { - egg_stack.push_back(new EggTriangleFan((yyvsp[(2) - (2)]._string))); -} - break; - - case 137: -#line 1741 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 136: +#line 1749 "parser.yxx" +{ + egg_stack.push_back(new EggTriangleFan(yyvsp[0]._string)); +; + break;} +case 137: +#line 1753 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 138: -#line 1756 "parser.yxx" - { - egg_stack.push_back(new EggTriangleStrip((yyvsp[(2) - (2)]._string))); -} - break; - - case 139: -#line 1760 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 138: +#line 1768 "parser.yxx" +{ + egg_stack.push_back(new EggTriangleStrip(yyvsp[0]._string)); +; + break;} +case 139: +#line 1772 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 140: -#line 1775 "parser.yxx" - { - egg_stack.push_back(new EggPoint((yyvsp[(2) - (2)]._string))); -} - break; - - case 141: -#line 1779 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 140: +#line 1787 "parser.yxx" +{ + egg_stack.push_back(new EggPoint(yyvsp[0]._string)); +; + break;} +case 141: +#line 1791 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 142: -#line 1794 "parser.yxx" - { - egg_stack.push_back(new EggLine((yyvsp[(2) - (2)]._string))); -} - break; - - case 143: -#line 1798 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 142: +#line 1806 "parser.yxx" +{ + egg_stack.push_back(new EggLine(yyvsp[0]._string)); +; + break;} +case 143: +#line 1810 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 144: -#line 1813 "parser.yxx" - { - egg_stack.push_back(new EggNurbsSurface((yyvsp[(2) - (2)]._string))); -} - break; - - case 145: -#line 1817 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 144: +#line 1825 "parser.yxx" +{ + egg_stack.push_back(new EggNurbsSurface(yyvsp[0]._string)); +; + break;} +case 145: +#line 1829 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 146: -#line 1832 "parser.yxx" - { - egg_stack.push_back(new EggNurbsCurve((yyvsp[(2) - (2)]._string))); -} - break; - - case 147: -#line 1836 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 146: +#line 1844 "parser.yxx" +{ + egg_stack.push_back(new EggNurbsCurve(yyvsp[0]._string)); +; + break;} +case 147: +#line 1848 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 152: -#line 1866 "parser.yxx" - { +; + break;} +case 152: +#line 1878 "parser.yxx" +{ if (!egg_stack.back()->is_of_type(EggCompositePrimitive::get_class_type())) { eggyyerror("Not a composite primitive; components are not allowed here."); } else { PT(EggCompositePrimitive) comp = DCAST(EggCompositePrimitive, egg_stack.back()); - if ((yyvsp[(3) - (4)]._number) < 0 || (yyvsp[(3) - (4)]._number) >= comp->get_num_components()) { + if (yyvsp[-1]._number < 0 || yyvsp[-1]._number >= comp->get_num_components()) { eggyyerror("Invalid component number"); } } // We temporarily add an EggPolygon to the stack, just to receive // the component attributes. egg_stack.push_back(new EggPolygon); -} - break; - - case 153: -#line 1880 "parser.yxx" - { +; + break;} +case 153: +#line 1892 "parser.yxx" +{ PT(EggPrimitive) prim = DCAST(EggPrimitive, egg_stack.back()); egg_stack.pop_back(); PT(EggCompositePrimitive) comp = DCAST(EggCompositePrimitive, egg_stack.back()); - comp->set_component((int)(yyvsp[(3) - (7)]._number), prim); -} - break; - - case 161: -#line 1894 "parser.yxx" - { + comp->set_component((int)yyvsp[-4]._number, prim); +; + break;} +case 161: +#line 1906 "parser.yxx" +{ EggPrimitive *primitive = DCAST(EggPrimitive, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "alpha") == 0) { EggRenderMode::AlphaMode a = EggRenderMode::string_alpha_mode(strval); @@ -3918,25 +3031,23 @@ yyreduce: } else { eggyywarning("Unknown scalar " + name); } -} - break; - - case 173: -#line 1978 "parser.yxx" - { - EggNurbsCurve *curve = DCAST(EggNurbsCurve, (yyvsp[(2) - (2)]._egg)); +; + break;} +case 173: +#line 1990 "parser.yxx" +{ + EggNurbsCurve *curve = DCAST(EggNurbsCurve, yyvsp[0]._egg); EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); nurbs->_curves_on_surface.push_back(curve); -} - break; - - case 175: -#line 1985 "parser.yxx" - { +; + break;} +case 175: +#line 1997 "parser.yxx" +{ EggNurbsSurface *primitive = DCAST(EggNurbsSurface, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "alpha") == 0) { EggRenderMode::AlphaMode a = EggRenderMode::string_alpha_mode(strval); @@ -3983,16 +3094,15 @@ yyreduce: } else { eggyywarning("Unknown scalar " + name); } -} - break; - - case 186: -#line 2059 "parser.yxx" - { +; + break;} +case 186: +#line 2071 "parser.yxx" +{ EggNurbsCurve *primitive = DCAST(EggNurbsCurve, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "alpha") == 0) { EggRenderMode::AlphaMode a = EggRenderMode::string_alpha_mode(strval); @@ -4045,26 +3155,24 @@ yyreduce: } else { eggyywarning("Unknown scalar " + name); } -} - break; - - case 187: -#line 2128 "parser.yxx" - { - if ((yyvsp[(1) - (1)]._egg) != (EggTexture *)NULL) { - EggTexture *texture = DCAST(EggTexture, (yyvsp[(1) - (1)]._egg)); +; + break;} +case 187: +#line 2140 "parser.yxx" +{ + if (yyvsp[0]._egg != (EggTexture *)NULL) { + EggTexture *texture = DCAST(EggTexture, yyvsp[0]._egg); DCAST(EggPrimitive, egg_stack.back())->add_texture(texture); } -} - break; - - case 188: -#line 2145 "parser.yxx" - { +; + break;} +case 188: +#line 2157 "parser.yxx" +{ EggTexture *texture = NULL; // Defining a texture on-the-fly. - Filename filename = (yyvsp[(1) - (1)]._string); + Filename filename = yyvsp[0]._string; string tref_name = filename.get_basename(); Textures::iterator vpi = textures.find(tref_name); @@ -4088,93 +3196,84 @@ yyreduce: nassertr(texture != NULL, 0); DCAST(EggPrimitive, egg_stack.back())->add_texture(texture); -} - break; - - case 189: -#line 2185 "parser.yxx" - { - if ((yyvsp[(1) - (1)]._egg) != (EggMaterial *)NULL) { - EggMaterial *material = DCAST(EggMaterial, (yyvsp[(1) - (1)]._egg)); +; + break;} +case 189: +#line 2197 "parser.yxx" +{ + if (yyvsp[0]._egg != (EggMaterial *)NULL) { + EggMaterial *material = DCAST(EggMaterial, yyvsp[0]._egg); DCAST(EggPrimitive, egg_stack.back())->set_material(material); } -} - break; - - case 190: -#line 2202 "parser.yxx" - { - DCAST(EggPrimitive, egg_stack.back())->set_normal(Normald((yyvsp[(1) - (3)]._number), (yyvsp[(2) - (3)]._number), (yyvsp[(3) - (3)]._number))); -} - break; - - case 191: -#line 2206 "parser.yxx" - { - bool inserted = DCAST(EggPrimitive, egg_stack.back())->_dnormals. - insert(EggMorphNormal((yyvsp[(3) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; - if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (8)]._string)); - } -} - break; - - case 192: +; + break;} +case 190: #line 2214 "parser.yxx" - { +{ + DCAST(EggPrimitive, egg_stack.back())->set_normal(Normald(yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 191: +#line 2218 "parser.yxx" +{ bool inserted = DCAST(EggPrimitive, egg_stack.back())->_dnormals. - insert(EggMorphNormal((yyvsp[(4) - (8)]._string), LVector3d((yyvsp[(5) - (8)]._number), (yyvsp[(6) - (8)]._number), (yyvsp[(7) - (8)]._number)))).second; + insert(EggMorphNormal(yyvsp[-5]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (8)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); } -} - break; - - case 193: -#line 2232 "parser.yxx" - { - DCAST(EggPrimitive, egg_stack.back())->set_color(Colorf((yyvsp[(1) - (4)]._number), (yyvsp[(2) - (4)]._number), (yyvsp[(3) - (4)]._number), (yyvsp[(4) - (4)]._number))); -} - break; - - case 194: -#line 2236 "parser.yxx" - { - bool inserted = DCAST(EggPrimitive, egg_stack.back())->_drgbas. - insert(EggMorphColor((yyvsp[(3) - (9)]._string), LVector4f((yyvsp[(5) - (9)]._number), (yyvsp[(6) - (9)]._number), (yyvsp[(7) - (9)]._number), (yyvsp[(8) - (9)]._number)))).second; +; + break;} +case 192: +#line 2226 "parser.yxx" +{ + bool inserted = DCAST(EggPrimitive, egg_stack.back())->_dnormals. + insert(EggMorphNormal(yyvsp[-4]._string, LVector3d(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(3) - (9)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-4]._string); } -} - break; - - case 195: +; + break;} +case 193: #line 2244 "parser.yxx" - { +{ + DCAST(EggPrimitive, egg_stack.back())->set_color(Colorf(yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number, yyvsp[0]._number)); +; + break;} +case 194: +#line 2248 "parser.yxx" +{ bool inserted = DCAST(EggPrimitive, egg_stack.back())->_drgbas. - insert(EggMorphColor((yyvsp[(4) - (9)]._string), LVector4f((yyvsp[(5) - (9)]._number), (yyvsp[(6) - (9)]._number), (yyvsp[(7) - (9)]._number), (yyvsp[(8) - (9)]._number)))).second; + insert(EggMorphColor(yyvsp[-6]._string, LVector4f(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; if (!inserted) { - eggyywarning("Ignoring repeated morph name " + (yyvsp[(4) - (9)]._string)); + eggyywarning("Ignoring repeated morph name " + yyvsp[-6]._string); } -} - break; - - case 196: -#line 2262 "parser.yxx" - { +; + break;} +case 195: +#line 2256 "parser.yxx" +{ + bool inserted = DCAST(EggPrimitive, egg_stack.back())->_drgbas. + insert(EggMorphColor(yyvsp[-5]._string, LVector4f(yyvsp[-4]._number, yyvsp[-3]._number, yyvsp[-2]._number, yyvsp[-1]._number))).second; + if (!inserted) { + eggyywarning("Ignoring repeated morph name " + yyvsp[-5]._string); + } +; + break;} +case 196: +#line 2274 "parser.yxx" +{ EggPrimitive *primitive = DCAST(EggPrimitive, egg_stack.back()); - int value = (int)(yyvsp[(1) - (1)]._number); + int value = (int)yyvsp[0]._number; primitive->set_bface_flag(value!=0); -} - break; - - case 197: -#line 2278 "parser.yxx" - { - if ((yyvsp[(6) - (8)]._egg) != (EggVertexPool *)NULL) { - EggVertexPool *pool = DCAST(EggVertexPool, (yyvsp[(6) - (8)]._egg)); +; + break;} +case 197: +#line 2290 "parser.yxx" +{ + if (yyvsp[-2]._egg != (EggVertexPool *)NULL) { + EggVertexPool *pool = DCAST(EggVertexPool, yyvsp[-2]._egg); EggPrimitive *prim = DCAST(EggPrimitive, egg_stack.back()); - PTA_double nums = (yyvsp[(3) - (8)]._number_list); + PTA_double nums = yyvsp[-5]._number_list; for (int i = 0; i < (int)nums.size(); i++) { int index = (int)nums[i]; @@ -4189,226 +3288,202 @@ yyreduce: } } } -} - break; - - case 198: -#line 2309 "parser.yxx" - { +; + break;} +case 198: +#line 2321 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); - int u_order = (int)(yyvsp[(1) - (2)]._number); - int v_order = (int)(yyvsp[(2) - (2)]._number); + int u_order = (int)yyvsp[-1]._number; + int v_order = (int)yyvsp[0]._number; nurbs->set_u_order(u_order); nurbs->set_v_order(v_order); -} - break; - - case 199: -#line 2327 "parser.yxx" - { +; + break;} +case 199: +#line 2339 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); - PTA_double nums = (yyvsp[(1) - (1)]._number_list); + PTA_double nums = yyvsp[0]._number_list; nurbs->set_num_u_knots(nums.size()); for (int i = 0; i < (int)nums.size(); i++) { nurbs->set_u_knot(i, nums[i]); } -} - break; - - case 200: -#line 2347 "parser.yxx" - { +; + break;} +case 200: +#line 2359 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); - PTA_double nums = (yyvsp[(1) - (1)]._number_list); + PTA_double nums = yyvsp[0]._number_list; nurbs->set_num_v_knots(nums.size()); for (int i = 0; i < (int)nums.size(); i++) { nurbs->set_v_knot(i, nums[i]); } -} - break; - - case 201: -#line 2367 "parser.yxx" - { +; + break;} +case 201: +#line 2379 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); nurbs->_trims.push_back(EggNurbsSurface::Trim()); -} - break; - - case 203: -#line 2383 "parser.yxx" - { +; + break;} +case 203: +#line 2395 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); nassertr(!nurbs->_trims.empty(), 0); nurbs->_trims.back().push_back(EggNurbsSurface::Loop()); -} - break; - - case 204: -#line 2389 "parser.yxx" - { +; + break;} +case 204: +#line 2401 "parser.yxx" +{ EggNurbsSurface *nurbs = DCAST(EggNurbsSurface, egg_stack.back()); nassertr(!nurbs->_trims.empty(), 0); nassertr(!nurbs->_trims.back().empty(), 0); - EggNurbsCurve *curve = DCAST(EggNurbsCurve, (yyvsp[(2) - (2)]._egg)); + EggNurbsCurve *curve = DCAST(EggNurbsCurve, yyvsp[0]._egg); nurbs->_trims.back().back().push_back(curve); -} - break; - - case 205: -#line 2408 "parser.yxx" - { +; + break;} +case 205: +#line 2420 "parser.yxx" +{ EggNurbsCurve *nurbs = DCAST(EggNurbsCurve, egg_stack.back()); - int order = (int)(yyvsp[(1) - (1)]._number); + int order = (int)yyvsp[0]._number; nurbs->set_order(order); -} - break; - - case 206: -#line 2424 "parser.yxx" - { +; + break;} +case 206: +#line 2436 "parser.yxx" +{ EggNurbsCurve *nurbs = DCAST(EggNurbsCurve, egg_stack.back()); - PTA_double nums = (yyvsp[(1) - (1)]._number_list); + PTA_double nums = yyvsp[0]._number_list; nurbs->set_num_knots(nums.size()); for (int i = 0; i < (int)nums.size(); i++) { nurbs->set_knot(i, nums[i]); } -} - break; - - case 207: -#line 2445 "parser.yxx" - { - EggTable *table = new EggTable((yyvsp[(2) - (2)]._string)); +; + break;} +case 207: +#line 2457 "parser.yxx" +{ + EggTable *table = new EggTable(yyvsp[0]._string); table->set_table_type(EggTable::TT_table); egg_stack.push_back(table); -} - break; - - case 208: -#line 2451 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 208: +#line 2463 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 209: -#line 2467 "parser.yxx" - { - EggTable *table = new EggTable((yyvsp[(2) - (2)]._string)); +; + break;} +case 209: +#line 2479 "parser.yxx" +{ + EggTable *table = new EggTable(yyvsp[0]._string); table->set_table_type(EggTable::TT_bundle); egg_stack.push_back(table); -} - break; - - case 210: -#line 2473 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 210: +#line 2485 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 212: -#line 2490 "parser.yxx" - { - DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 213: -#line 2494 "parser.yxx" - { - DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 214: -#line 2498 "parser.yxx" - { - DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 215: -#line 2502 "parser.yxx" - { - DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 216: -#line 2506 "parser.yxx" - { - DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 217: -#line 2521 "parser.yxx" - { - EggSAnimData *anim_data = new EggSAnimData((yyvsp[(2) - (2)]._string)); +; + break;} +case 212: +#line 2501 "parser.yxx" +{ + DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 213: +#line 2505 "parser.yxx" +{ + DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 214: +#line 2509 "parser.yxx" +{ + DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 215: +#line 2513 "parser.yxx" +{ + DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 216: +#line 2517 "parser.yxx" +{ + DCAST(EggTable, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 217: +#line 2532 "parser.yxx" +{ + EggSAnimData *anim_data = new EggSAnimData(yyvsp[0]._string); egg_stack.push_back(anim_data); -} - break; - - case 218: -#line 2526 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 218: +#line 2537 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 220: -#line 2543 "parser.yxx" - { +; + break;} +case 220: +#line 2554 "parser.yxx" +{ EggSAnimData *anim_data = DCAST(EggSAnimData, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; if (cmp_nocase_uh(name, "fps") == 0) { anim_data->set_fps(value); } else { eggyywarning("Unsupported S$Anim scalar: " + name); } -} - break; - - case 221: -#line 2555 "parser.yxx" - { - DCAST(EggSAnimData, egg_stack.back())->set_data((yyvsp[(4) - (5)]._number_list)); -} - break; - - case 222: -#line 2569 "parser.yxx" - { - EggXfmAnimData *anim_data = new EggXfmAnimData((yyvsp[(2) - (2)]._string)); +; + break;} +case 221: +#line 2566 "parser.yxx" +{ + DCAST(EggSAnimData, egg_stack.back())->set_data(yyvsp[-1]._number_list); +; + break;} +case 222: +#line 2580 "parser.yxx" +{ + EggXfmAnimData *anim_data = new EggXfmAnimData(yyvsp[0]._string); egg_stack.push_back(anim_data); -} - break; - - case 223: -#line 2574 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 223: +#line 2585 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 225: -#line 2591 "parser.yxx" - { +; + break;} +case 225: +#line 2602 "parser.yxx" +{ EggXfmAnimData *anim_data = DCAST(EggXfmAnimData, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "fps") == 0) { anim_data->set_fps(value); @@ -4419,39 +3494,35 @@ yyreduce: } else { eggyywarning("Unsupported Xfm$Anim scalar: " + name); } -} - break; - - case 226: -#line 2608 "parser.yxx" - { - DCAST(EggXfmAnimData, egg_stack.back())->set_data((yyvsp[(4) - (5)]._number_list)); -} - break; - - case 227: -#line 2622 "parser.yxx" - { - EggXfmSAnim *anim_group = new EggXfmSAnim((yyvsp[(2) - (2)]._string)); +; + break;} +case 226: +#line 2619 "parser.yxx" +{ + DCAST(EggXfmAnimData, egg_stack.back())->set_data(yyvsp[-1]._number_list); +; + break;} +case 227: +#line 2633 "parser.yxx" +{ + EggXfmSAnim *anim_group = new EggXfmSAnim(yyvsp[0]._string); egg_stack.push_back(anim_group); -} - break; - - case 228: -#line 2627 "parser.yxx" - { - (yyval._egg) = egg_stack.back(); +; + break;} +case 228: +#line 2638 "parser.yxx" +{ + yyval._egg = egg_stack.back(); egg_stack.pop_back(); -} - break; - - case 230: -#line 2644 "parser.yxx" - { +; + break;} +case 230: +#line 2655 "parser.yxx" +{ EggXfmSAnim *anim_group = DCAST(EggXfmSAnim, egg_stack.back()); - string name = (yyvsp[(3) - (6)]._string); - double value = (yyvsp[(5) - (6)]._number); - string strval = (yyvsp[(5) - (6)]._string); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; + string strval = yyvsp[-1]._string; if (cmp_nocase_uh(name, "fps") == 0) { anim_group->set_fps(value); @@ -4460,76 +3531,98 @@ yyreduce: } else { eggyywarning("Unsupported Xfm$Anim_S$ scalar: " + name); } -} - break; +; + break;} +case 231: +#line 2670 "parser.yxx" +{ + DCAST(EggXfmSAnim, egg_stack.back())->add_child(DCAST(EggNode, yyvsp[0]._egg)); +; + break;} +case 232: +#line 2685 "parser.yxx" +{ + EggAnimPreload *anim_preload = new EggAnimPreload(yyvsp[0]._string); + egg_stack.push_back(anim_preload); +; + break;} +case 233: +#line 2690 "parser.yxx" +{ + yyval._egg = egg_stack.back(); + egg_stack.pop_back(); +; + break;} +case 235: +#line 2707 "parser.yxx" +{ + EggAnimPreload *anim_preload = DCAST(EggAnimPreload, egg_stack.back()); + string name = yyvsp[-3]._string; + double value = yyvsp[-1]._number; - case 231: -#line 2659 "parser.yxx" - { - DCAST(EggXfmSAnim, egg_stack.back())->add_child(DCAST(EggNode, (yyvsp[(2) - (2)]._egg))); -} - break; - - case 232: -#line 2674 "parser.yxx" - { - (yyval._number_list) = PTA_double::empty_array(0); -} - break; - - case 233: -#line 2678 "parser.yxx" - { - (yyval._number_list).push_back((double)(yyvsp[(2) - (2)]._number)); -} - break; - - case 234: -#line 2692 "parser.yxx" - { - (yyval._number_list) = PTA_double::empty_array(0); -} - break; - - case 235: -#line 2696 "parser.yxx" - { - (yyval._number_list).push_back((yyvsp[(2) - (2)]._number)); -} - break; - - case 236: -#line 2710 "parser.yxx" - { - string name = (yyvsp[(1) - (1)]._string); + if (cmp_nocase_uh(name, "fps") == 0) { + anim_preload->set_fps(value); + } else if (cmp_nocase_uh(name, "frames") == 0) { + anim_preload->set_num_frames((int)value); + } else { + eggyywarning("Unsupported AnimPreload scalar: " + name); + } +; + break;} +case 236: +#line 2731 "parser.yxx" +{ + yyval._number_list = PTA_double::empty_array(0); +; + break;} +case 237: +#line 2735 "parser.yxx" +{ + yyval._number_list.push_back((double)yyvsp[0]._number); +; + break;} +case 238: +#line 2749 "parser.yxx" +{ + yyval._number_list = PTA_double::empty_array(0); +; + break;} +case 239: +#line 2753 "parser.yxx" +{ + yyval._number_list.push_back(yyvsp[0]._number); +; + break;} +case 240: +#line 2767 "parser.yxx" +{ + string name = yyvsp[0]._string; Textures::iterator vpi = textures.find(name); if (vpi == textures.end()) { eggyyerror("Unknown texture " + name); - (yyval._egg) = PT(EggObject)(); + yyval._egg = PT(EggObject)(); } else { - (yyval._egg) = (*vpi).second; + yyval._egg = (*vpi).second; } -} - break; - - case 237: -#line 2731 "parser.yxx" - { - string name = (yyvsp[(1) - (1)]._string); +; + break;} +case 241: +#line 2788 "parser.yxx" +{ + string name = yyvsp[0]._string; Materials::iterator vpi = materials.find(name); if (vpi == materials.end()) { eggyyerror("Unknown material " + name); - (yyval._egg) = PT(EggObject)(); + yyval._egg = PT(EggObject)(); } else { - (yyval._egg) = (*vpi).second; + yyval._egg = (*vpi).second; } -} - break; - - case 238: -#line 2752 "parser.yxx" - { - string name = (yyvsp[(1) - (1)]._string); +; + break;} +case 242: +#line 2809 "parser.yxx" +{ + string name = yyvsp[0]._string; VertexPools::iterator vpi = vertex_pools.find(name); if (vpi == vertex_pools.end()) { // This will become a forward reference. @@ -4537,344 +3630,334 @@ yyreduce: // The egg syntax starts counting at 1 by convention. pool->set_highest_index(0); vertex_pools[name] = pool; - (yyval._egg) = pool; + yyval._egg = pool; } else { - (yyval._egg) = (*vpi).second; + yyval._egg = (*vpi).second; } -} - break; - - case 239: -#line 2778 "parser.yxx" - { +; + break;} +case 243: +#line 2835 "parser.yxx" +{ eggyyerror("Name required."); - (yyval._string) = ""; -} - break; - - case 242: -#line 2807 "parser.yxx" - { + yyval._string = ""; +; + break;} +case 246: +#line 2864 "parser.yxx" +{ eggyyerror("String required."); - (yyval._string) = ""; -} - break; - - case 244: -#line 2823 "parser.yxx" - { - (yyval._string) = ""; -} - break; - - case 246: -#line 2841 "parser.yxx" - { - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 247: -#line 2845 "parser.yxx" - { - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 249: -#line 2862 "parser.yxx" - { - (yyval._string) = ""; -} - break; - - case 250: -#line 2866 "parser.yxx" - { - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 251: -#line 2882 "parser.yxx" - { - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 252: -#line 2886 "parser.yxx" - { - (yyval._string) = (yyvsp[(1) - (2)]._string) + "\n" + (yyvsp[(2) - (2)]._string); -} - break; - - case 254: -#line 2901 "parser.yxx" - { - (yyval._number) = (yyvsp[(1) - (1)]._ulong); -} - break; - - case 255: -#line 2916 "parser.yxx" - { - (yyval._number) = (yyvsp[(1) - (1)]._number); - (yyval._ulong) = (unsigned long)(yyvsp[(1) - (1)]._number); - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 256: -#line 2922 "parser.yxx" - { - (yyval._number) = (yyvsp[(1) - (1)]._ulong); - (yyval._ulong) = (yyvsp[(1) - (1)]._ulong); - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 257: -#line 2928 "parser.yxx" - { - (yyval._number) = 0.0; - (yyval._ulong) = 0; - (yyval._string) = (yyvsp[(1) - (1)]._string); -} - break; - - case 258: -#line 2945 "parser.yxx" - { - int i = (int)(yyvsp[(1) - (1)]._number); - if ((double)i != (yyvsp[(1) - (1)]._number)) { + yyval._string = ""; +; + break;} +case 248: +#line 2880 "parser.yxx" +{ + yyval._string = ""; +; + break;} +case 250: +#line 2898 "parser.yxx" +{ + yyval._string = yyvsp[0]._string; +; + break;} +case 251: +#line 2902 "parser.yxx" +{ + yyval._string = yyvsp[0]._string; +; + break;} +case 253: +#line 2919 "parser.yxx" +{ + yyval._string = ""; +; + break;} +case 254: +#line 2923 "parser.yxx" +{ + yyval._string = yyvsp[0]._string; +; + break;} +case 255: +#line 2939 "parser.yxx" +{ + yyval._string = yyvsp[0]._string; +; + break;} +case 256: +#line 2943 "parser.yxx" +{ + yyval._string = yyvsp[-1]._string + "\n" + yyvsp[0]._string; +; + break;} +case 258: +#line 2958 "parser.yxx" +{ + yyval._number = yyvsp[0]._ulong; +; + break;} +case 259: +#line 2973 "parser.yxx" +{ + yyval._number = yyvsp[0]._number; + yyval._ulong = (unsigned long)yyvsp[0]._number; + yyval._string = yyvsp[0]._string; +; + break;} +case 260: +#line 2979 "parser.yxx" +{ + yyval._number = yyvsp[0]._ulong; + yyval._ulong = yyvsp[0]._ulong; + yyval._string = yyvsp[0]._string; +; + break;} +case 261: +#line 2985 "parser.yxx" +{ + yyval._number = 0.0; + yyval._ulong = 0; + yyval._string = yyvsp[0]._string; +; + break;} +case 262: +#line 3002 "parser.yxx" +{ + int i = (int)yyvsp[0]._number; + if ((double)i != yyvsp[0]._number) { eggyywarning("Integer expected."); - (yyval._number) = (double)i; + yyval._number = (double)i; } +; + break;} +case 263: +#line 3010 "parser.yxx" +{ + yyval._number = yyvsp[0]._ulong; +; + break;} } - break; + /* the action file gets copied in in place of this dollarsign */ +#line 543 "/usr/share/bison.simple" + + yyvsp -= yylen; + yyssp -= yylen; +#ifdef YYLSP_NEEDED + yylsp -= yylen; +#endif - case 259: -#line 2953 "parser.yxx" +#if YYDEBUG != 0 + if (yydebug) { - (yyval._number) = (yyvsp[(1) - (1)]._ulong); -} - break; - - -/* Line 1267 of yacc.c. */ -#line 4667 "y.tab.c" - default: break; + short *ssp1 = yyss - 1; + fprintf (stderr, "state stack now"); + while (ssp1 != yyssp) + fprintf (stderr, " %d", *++ssp1); + fprintf (stderr, "\n"); } - YY_SYMBOL_PRINT ("-> $$ =", yyr1[yyn], &yyval, &yyloc); - - YYPOPSTACK (yylen); - yylen = 0; - YY_STACK_PRINT (yyss, yyssp); +#endif *++yyvsp = yyval; +#ifdef YYLSP_NEEDED + yylsp++; + if (yylen == 0) + { + yylsp->first_line = yylloc.first_line; + yylsp->first_column = yylloc.first_column; + yylsp->last_line = (yylsp-1)->last_line; + yylsp->last_column = (yylsp-1)->last_column; + yylsp->text = 0; + } + else + { + yylsp->last_line = (yylsp+yylen-1)->last_line; + yylsp->last_column = (yylsp+yylen-1)->last_column; + } +#endif - /* Now `shift' the result of the reduction. Determine what state - that goes to, based on the state we popped back to and the rule - number reduced by. */ + /* Now "shift" the result of the reduction. + Determine what state that goes to, + based on the state we popped back to + and the rule number reduced by. */ yyn = yyr1[yyn]; - yystate = yypgoto[yyn - YYNTOKENS] + *yyssp; - if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp) + yystate = yypgoto[yyn - YYNTBASE] + *yyssp; + if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp) yystate = yytable[yystate]; else - yystate = yydefgoto[yyn - YYNTOKENS]; + yystate = yydefgoto[yyn - YYNTBASE]; goto yynewstate; +yyerrlab: /* here on detecting error */ -/*------------------------------------. -| yyerrlab -- here on detecting error | -`------------------------------------*/ -yyerrlab: - /* If not already recovering from an error, report this error. */ - if (!yyerrstatus) + if (! yyerrstatus) + /* If not already recovering from an error, report this error. */ { ++yynerrs; -#if ! YYERROR_VERBOSE - yyerror (YY_("syntax error")); -#else - { - YYSIZE_T yysize = yysyntax_error (0, yystate, yychar); - if (yymsg_alloc < yysize && yymsg_alloc < YYSTACK_ALLOC_MAXIMUM) - { - YYSIZE_T yyalloc = 2 * yysize; - if (! (yysize <= yyalloc && yyalloc <= YYSTACK_ALLOC_MAXIMUM)) - yyalloc = YYSTACK_ALLOC_MAXIMUM; - if (yymsg != yymsgbuf) - YYSTACK_FREE (yymsg); - yymsg = (char *) YYSTACK_ALLOC (yyalloc); - if (yymsg) - yymsg_alloc = yyalloc; - else - { - yymsg = yymsgbuf; - yymsg_alloc = sizeof yymsgbuf; - } - } - if (0 < yysize && yysize <= yymsg_alloc) - { - (void) yysyntax_error (yymsg, yystate, yychar); - yyerror (yymsg); - } - else - { - yyerror (YY_("syntax error")); - if (yysize != 0) - goto yyexhaustedlab; - } - } -#endif +#ifdef YYERROR_VERBOSE + yyn = yypact[yystate]; + + if (yyn > YYFLAG && yyn < YYLAST) + { + int size = 0; + char *msg; + int x, count; + + count = 0; + /* Start X at -yyn if nec to avoid negative indexes in yycheck. */ + for (x = (yyn < 0 ? -yyn : 0); + x < (sizeof(yytname) / sizeof(char *)); x++) + if (yycheck[x + yyn] == x) + size += strlen(yytname[x]) + 15, count++; + msg = (char *) malloc(size + 15); + if (msg != 0) + { + strcpy(msg, "parse error"); + + if (count < 5) + { + count = 0; + for (x = (yyn < 0 ? -yyn : 0); + x < (sizeof(yytname) / sizeof(char *)); x++) + if (yycheck[x + yyn] == x) + { + strcat(msg, count == 0 ? ", expecting `" : " or `"); + strcat(msg, yytname[x]); + strcat(msg, "'"); + count++; + } + } + yyerror(msg); + free(msg); + } + else + yyerror ("parse error; also virtual memory exceeded"); + } + else +#endif /* YYERROR_VERBOSE */ + yyerror("parse error"); } - + goto yyerrlab1; +yyerrlab1: /* here on error raised explicitly by an action */ if (yyerrstatus == 3) { - /* If just tried and failed to reuse look-ahead token after an - error, discard it. */ + /* if just tried and failed to reuse lookahead token after an error, discard it. */ - if (yychar <= YYEOF) - { - /* Return failure if at end of input. */ - if (yychar == YYEOF) - YYABORT; - } - else - { - yydestruct ("Error: discarding", - yytoken, &yylval); - yychar = YYEMPTY; - } - } - - /* Else will try to reuse look-ahead token after shifting the error - token. */ - goto yyerrlab1; - - -/*---------------------------------------------------. -| yyerrorlab -- error raised explicitly by YYERROR. | -`---------------------------------------------------*/ -yyerrorlab: - - /* Pacify compilers like GCC when the user code never invokes - YYERROR and the label yyerrorlab therefore never appears in user - code. */ - if (/*CONSTCOND*/ 0) - goto yyerrorlab; - - /* Do not reclaim the symbols of the rule which action triggered - this YYERROR. */ - YYPOPSTACK (yylen); - yylen = 0; - YY_STACK_PRINT (yyss, yyssp); - yystate = *yyssp; - goto yyerrlab1; - - -/*-------------------------------------------------------------. -| yyerrlab1 -- common code for both syntax error and YYERROR. | -`-------------------------------------------------------------*/ -yyerrlab1: - yyerrstatus = 3; /* Each real token shifted decrements this. */ - - for (;;) - { - yyn = yypact[yystate]; - if (yyn != YYPACT_NINF) - { - yyn += YYTERROR; - if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) - { - yyn = yytable[yyn]; - if (0 < yyn) - break; - } - } - - /* Pop the current state because it cannot handle the error token. */ - if (yyssp == yyss) + /* return failure if at end of input */ + if (yychar == YYEOF) YYABORT; +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Discarding token %d (%s).\n", yychar, yytname[yychar1]); +#endif - yydestruct ("Error: popping", - yystos[yystate], yyvsp); - YYPOPSTACK (1); - yystate = *yyssp; - YY_STACK_PRINT (yyss, yyssp); + yychar = YYEMPTY; } + /* Else will try to reuse lookahead token + after shifting the error token. */ + + yyerrstatus = 3; /* Each real token shifted decrements this */ + + goto yyerrhandle; + +yyerrdefault: /* current state does not do anything special for the error token. */ + +#if 0 + /* This is wrong; only states that explicitly want error tokens + should shift them. */ + yyn = yydefact[yystate]; /* If its default is to accept any token, ok. Otherwise pop it.*/ + if (yyn) goto yydefault; +#endif + +yyerrpop: /* pop the current state because it cannot handle the error token */ + + if (yyssp == yyss) YYABORT; + yyvsp--; + yystate = *--yyssp; +#ifdef YYLSP_NEEDED + yylsp--; +#endif + +#if YYDEBUG != 0 + if (yydebug) + { + short *ssp1 = yyss - 1; + fprintf (stderr, "Error: state stack now"); + while (ssp1 != yyssp) + fprintf (stderr, " %d", *++ssp1); + fprintf (stderr, "\n"); + } +#endif + +yyerrhandle: + + yyn = yypact[yystate]; + if (yyn == YYFLAG) + goto yyerrdefault; + + yyn += YYTERROR; + if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != YYTERROR) + goto yyerrdefault; + + yyn = yytable[yyn]; + if (yyn < 0) + { + if (yyn == YYFLAG) + goto yyerrpop; + yyn = -yyn; + goto yyreduce; + } + else if (yyn == 0) + goto yyerrpop; + if (yyn == YYFINAL) YYACCEPT; +#if YYDEBUG != 0 + if (yydebug) + fprintf(stderr, "Shifting error token, "); +#endif + *++yyvsp = yylval; - - - /* Shift the error token. */ - YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp); +#ifdef YYLSP_NEEDED + *++yylsp = yylloc; +#endif yystate = yyn; goto yynewstate; - -/*-------------------------------------. -| yyacceptlab -- YYACCEPT comes here. | -`-------------------------------------*/ -yyacceptlab: - yyresult = 0; - goto yyreturn; - -/*-----------------------------------. -| yyabortlab -- YYABORT comes here. | -`-----------------------------------*/ -yyabortlab: - yyresult = 1; - goto yyreturn; - -#ifndef yyoverflow -/*-------------------------------------------------. -| yyexhaustedlab -- memory exhaustion comes here. | -`-------------------------------------------------*/ -yyexhaustedlab: - yyerror (YY_("memory exhausted")); - yyresult = 2; - /* Fall through. */ -#endif - -yyreturn: - if (yychar != YYEOF && yychar != YYEMPTY) - yydestruct ("Cleanup: discarding lookahead", - yytoken, &yylval); - /* Do not reclaim the symbols of the rule which action triggered - this YYABORT or YYACCEPT. */ - YYPOPSTACK (yylen); - YY_STACK_PRINT (yyss, yyssp); - while (yyssp != yyss) + yyacceptlab: + /* YYACCEPT comes here. */ + if (yyfree_stacks) { - yydestruct ("Cleanup: popping", - yystos[*yyssp], yyvsp); - YYPOPSTACK (1); + free (yyss); + free (yyvs); +#ifdef YYLSP_NEEDED + free (yyls); +#endif } -#ifndef yyoverflow - if (yyss != yyssa) - YYSTACK_FREE (yyss); + return 0; + + yyabortlab: + /* YYABORT comes here. */ + if (yyfree_stacks) + { + free (yyss); + free (yyvs); +#ifdef YYLSP_NEEDED + free (yyls); #endif -#if YYERROR_VERBOSE - if (yymsg != yymsgbuf) - YYSTACK_FREE (yymsg); -#endif - /* Make sure YYID is used. */ - return YYID (yyresult); + } + return 1; } - - - +#line 3017 "parser.yxx" diff --git a/panda/src/egg/parser.h.prebuilt b/panda/src/egg/parser.h.prebuilt index f34f7de9e8..86f1627b11 100644 --- a/panda/src/egg/parser.h.prebuilt +++ b/panda/src/egg/parser.h.prebuilt @@ -1,233 +1,92 @@ -/* A Bison parser, made by GNU Bison 2.3. */ +#define EGG_NUMBER 257 +#define EGG_ULONG 258 +#define EGG_STRING 259 +#define ANIMPRELOAD 260 +#define BEZIERCURVE 261 +#define BFACE 262 +#define BILLBOARD 263 +#define BILLBOARDCENTER 264 +#define BINORMAL 265 +#define BUNDLE 266 +#define CLOSED 267 +#define COLLIDE 268 +#define COMMENT 269 +#define COMPONENT 270 +#define COORDSYSTEM 271 +#define CV 272 +#define DART 273 +#define DNORMAL 274 +#define DRGBA 275 +#define DUV 276 +#define DXYZ 277 +#define DCS 278 +#define DISTANCE 279 +#define DTREF 280 +#define DYNAMICVERTEXPOOL 281 +#define EXTERNAL_FILE 282 +#define FLIGHT 283 +#define GROUP 284 +#define HIP 285 +#define INTANGENT 286 +#define JOINT 287 +#define KNOTS 288 +#define INCLUDE 289 +#define INSTANCE 290 +#define LINE 291 +#define LOOP 292 +#define MATERIAL 293 +#define MATRIX3 294 +#define MATRIX4 295 +#define MODEL 296 +#define MREF 297 +#define NORMAL 298 +#define NURBSCURVE 299 +#define NURBSSURFACE 300 +#define OBJECTTYPE 301 +#define ORDER 302 +#define OUTTANGENT 303 +#define POINTLIGHT 304 +#define POLYGON 305 +#define REF 306 +#define RGBA 307 +#define ROTATE 308 +#define ROTX 309 +#define ROTY 310 +#define ROTZ 311 +#define SANIM 312 +#define SCALAR 313 +#define SCALE 314 +#define SEQUENCE 315 +#define SHADING 316 +#define SWITCH 317 +#define SWITCHCONDITION 318 +#define TABLE 319 +#define TABLE_V 320 +#define TAG 321 +#define TANGENT 322 +#define TEXLIST 323 +#define TEXTURE 324 +#define TLENGTHS 325 +#define TRANSFORM 326 +#define TRANSLATE 327 +#define TREF 328 +#define TRIANGLEFAN 329 +#define TRIANGLESTRIP 330 +#define TRIM 331 +#define TXT 332 +#define UKNOTS 333 +#define UV 334 +#define VKNOTS 335 +#define VERTEX 336 +#define VERTEXANIM 337 +#define VERTEXPOOL 338 +#define VERTEXREF 339 +#define XFMANIM 340 +#define XFMSANIM 341 +#define START_EGG 342 +#define START_GROUP_BODY 343 +#define START_TEXTURE_BODY 344 +#define START_PRIMITIVE_BODY 345 -/* Skeleton interface for Bison's Yacc-like parsers in C - - Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006 - Free Software Foundation, Inc. - - 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. */ - -/* As a special exception, you may create a larger work that contains - part or all of the Bison parser skeleton and distribute that work - under terms of your choice, so long as that work isn't itself a - parser generator using the skeleton or a modified version thereof - as a parser skeleton. Alternatively, if you modify or redistribute - the parser skeleton itself, you may (at your option) remove this - special exception, which will cause the skeleton and the resulting - Bison output files to be licensed under the GNU General Public - License without this special exception. - - This special exception was added by the Free Software Foundation in - version 2.2 of Bison. */ - -/* Tokens. */ -#ifndef YYTOKENTYPE -# define YYTOKENTYPE - /* Put the tokens into the symbol table, so that GDB and other debuggers - know about them. */ - enum yytokentype { - EGG_NUMBER = 258, - EGG_ULONG = 259, - EGG_STRING = 260, - BEZIERCURVE = 261, - BFACE = 262, - BILLBOARD = 263, - BILLBOARDCENTER = 264, - BINORMAL = 265, - BUNDLE = 266, - CLOSED = 267, - COLLIDE = 268, - COMMENT = 269, - COMPONENT = 270, - COORDSYSTEM = 271, - CV = 272, - DART = 273, - DNORMAL = 274, - DRGBA = 275, - DUV = 276, - DXYZ = 277, - DCS = 278, - DISTANCE = 279, - DTREF = 280, - DYNAMICVERTEXPOOL = 281, - EXTERNAL_FILE = 282, - FLIGHT = 283, - GROUP = 284, - HIP = 285, - INTANGENT = 286, - JOINT = 287, - KNOTS = 288, - INCLUDE = 289, - INSTANCE = 290, - LINE = 291, - LOOP = 292, - MATERIAL = 293, - MATRIX3 = 294, - MATRIX4 = 295, - MODEL = 296, - MREF = 297, - NORMAL = 298, - NURBSCURVE = 299, - NURBSSURFACE = 300, - OBJECTTYPE = 301, - ORDER = 302, - OUTTANGENT = 303, - POINTLIGHT = 304, - POLYGON = 305, - REF = 306, - RGBA = 307, - ROTATE = 308, - ROTX = 309, - ROTY = 310, - ROTZ = 311, - SANIM = 312, - SCALAR = 313, - SCALE = 314, - SEQUENCE = 315, - SHADING = 316, - SWITCH = 317, - SWITCHCONDITION = 318, - TABLE = 319, - TABLE_V = 320, - TAG = 321, - TANGENT = 322, - TEXLIST = 323, - TEXTURE = 324, - TLENGTHS = 325, - TRANSFORM = 326, - TRANSLATE = 327, - TREF = 328, - TRIANGLEFAN = 329, - TRIANGLESTRIP = 330, - TRIM = 331, - TXT = 332, - UKNOTS = 333, - UV = 334, - VKNOTS = 335, - VERTEX = 336, - VERTEXANIM = 337, - VERTEXPOOL = 338, - VERTEXREF = 339, - XFMANIM = 340, - XFMSANIM = 341, - START_EGG = 342, - START_GROUP_BODY = 343, - START_TEXTURE_BODY = 344, - START_PRIMITIVE_BODY = 345 - }; -#endif -/* Tokens. */ -#define EGG_NUMBER 258 -#define EGG_ULONG 259 -#define EGG_STRING 260 -#define BEZIERCURVE 261 -#define BFACE 262 -#define BILLBOARD 263 -#define BILLBOARDCENTER 264 -#define BINORMAL 265 -#define BUNDLE 266 -#define CLOSED 267 -#define COLLIDE 268 -#define COMMENT 269 -#define COMPONENT 270 -#define COORDSYSTEM 271 -#define CV 272 -#define DART 273 -#define DNORMAL 274 -#define DRGBA 275 -#define DUV 276 -#define DXYZ 277 -#define DCS 278 -#define DISTANCE 279 -#define DTREF 280 -#define DYNAMICVERTEXPOOL 281 -#define EXTERNAL_FILE 282 -#define FLIGHT 283 -#define GROUP 284 -#define HIP 285 -#define INTANGENT 286 -#define JOINT 287 -#define KNOTS 288 -#define INCLUDE 289 -#define INSTANCE 290 -#define LINE 291 -#define LOOP 292 -#define MATERIAL 293 -#define MATRIX3 294 -#define MATRIX4 295 -#define MODEL 296 -#define MREF 297 -#define NORMAL 298 -#define NURBSCURVE 299 -#define NURBSSURFACE 300 -#define OBJECTTYPE 301 -#define ORDER 302 -#define OUTTANGENT 303 -#define POINTLIGHT 304 -#define POLYGON 305 -#define REF 306 -#define RGBA 307 -#define ROTATE 308 -#define ROTX 309 -#define ROTY 310 -#define ROTZ 311 -#define SANIM 312 -#define SCALAR 313 -#define SCALE 314 -#define SEQUENCE 315 -#define SHADING 316 -#define SWITCH 317 -#define SWITCHCONDITION 318 -#define TABLE 319 -#define TABLE_V 320 -#define TAG 321 -#define TANGENT 322 -#define TEXLIST 323 -#define TEXTURE 324 -#define TLENGTHS 325 -#define TRANSFORM 326 -#define TRANSLATE 327 -#define TREF 328 -#define TRIANGLEFAN 329 -#define TRIANGLESTRIP 330 -#define TRIM 331 -#define TXT 332 -#define UKNOTS 333 -#define UV 334 -#define VKNOTS 335 -#define VERTEX 336 -#define VERTEXANIM 337 -#define VERTEXPOOL 338 -#define VERTEXREF 339 -#define XFMANIM 340 -#define XFMSANIM 341 -#define START_EGG 342 -#define START_GROUP_BODY 343 -#define START_TEXTURE_BODY 344 -#define START_PRIMITIVE_BODY 345 - - - - -#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED -typedef int YYSTYPE; -# define yystype YYSTYPE /* obsolescent; will be withdrawn */ -# define YYSTYPE_IS_DECLARED 1 -# define YYSTYPE_IS_TRIVIAL 1 -#endif extern YYSTYPE eggyylval; - diff --git a/panda/src/egg/parser.yxx b/panda/src/egg/parser.yxx index 79b6fd0810..f9c4f1544c 100644 --- a/panda/src/egg/parser.yxx +++ b/panda/src/egg/parser.yxx @@ -32,6 +32,7 @@ #include "eggCoordinateSystem.h" #include "eggExternalReference.h" #include "eggData.h" +#include "eggAnimPreload.h" #include "pt_EggTexture.h" #include "pt_EggMaterial.h" @@ -146,6 +147,7 @@ egg_cleanup_parser() { %token <_ulong> EGG_ULONG %token <_string> EGG_STRING +%token ANIMPRELOAD %token BEZIERCURVE BFACE BILLBOARD BILLBOARDCENTER BINORMAL BUNDLE CLOSED %token COLLIDE COMMENT COMPONENT %token COORDSYSTEM CV DART @@ -190,6 +192,7 @@ egg_cleanup_parser() { %type <_egg> nurbs_curve %type <_egg> table %type <_egg> bundle +%type <_egg> anim_preload %type <_egg> sanim %type <_egg> xfmanim %type <_egg> xfm_s_anim @@ -261,6 +264,7 @@ node: | nurbs_surface | nurbs_curve | table + | anim_preload ; /* @@ -2484,7 +2488,6 @@ bundle: } ; - /* * table_body * @@ -2670,6 +2673,52 @@ xfm_s_anim_body: ; +/* + * anim_preload + * + * enter: + * exit: returns a new EggAnimPreload object. + * + */ +anim_preload: + ANIMPRELOAD optional_name +{ + EggAnimPreload *anim_preload = new EggAnimPreload($2); + egg_stack.push_back(anim_preload); +} + '{' anim_preload_body '}' +{ + $$ = egg_stack.back(); + egg_stack.pop_back(); +} + ; + + +/* + * anim_preload_body + * + * enter: TOS is EggAnimPreload. + * exit: anim_preload contents have been filled. + * + */ +anim_preload_body: + empty + | anim_preload_body SCALAR required_name '{' real_or_string '}' +{ + EggAnimPreload *anim_preload = DCAST(EggAnimPreload, egg_stack.back()); + string name = $3; + double value = $<_number>5; + + if (cmp_nocase_uh(name, "fps") == 0) { + anim_preload->set_fps(value); + } else if (cmp_nocase_uh(name, "frames") == 0) { + anim_preload->set_num_frames((int)value); + } else { + eggyywarning("Unsupported AnimPreload scalar: " + name); + } +} + ; + /* * integer_list * diff --git a/panda/src/egg2pg/characterMaker.cxx b/panda/src/egg2pg/characterMaker.cxx index 53e5615825..e572efada7 100644 --- a/panda/src/egg2pg/characterMaker.cxx +++ b/panda/src/egg2pg/characterMaker.cxx @@ -32,6 +32,8 @@ #include "characterVertexSlider.h" #include "jointVertexTransform.h" #include "userVertexTransform.h" +#include "eggAnimPreload.h" +#include "animPreloadTable.h" //////////////////////////////////////////////////////////////////// // Function: CharacterMaker::Construtor @@ -238,6 +240,28 @@ make_bundle() { //////////////////////////////////////////////////////////////////// void CharacterMaker:: build_joint_hierarchy(EggNode *egg_node, PartGroup *part, int index) { + if (egg_node->is_of_type(EggAnimPreload::get_class_type())) { + EggAnimPreload *egg_anim_preload = DCAST(EggAnimPreload, egg_node); + + double fps = 24.0; + if (egg_anim_preload->has_fps()) { + fps = egg_anim_preload->get_fps(); + } + + int num_frames = 1; + if (egg_anim_preload->has_num_frames()) { + num_frames = egg_anim_preload->get_num_frames(); + } + + PT(AnimPreloadTable) anim_preload = _bundle->modify_anim_preload(); + if (anim_preload == (AnimPreloadTable *)NULL) { + anim_preload = new AnimPreloadTable; + _bundle->set_anim_preload(anim_preload); + } + anim_preload->add_anim(egg_node->get_name(), fps, num_frames); + return; + } + if (egg_node->is_of_type(EggGroup::get_class_type())) { EggGroup *egg_group = DCAST(EggGroup, egg_node); diff --git a/panda/src/event/eventQueue.cxx b/panda/src/event/eventQueue.cxx index 543a3eb986..858a3e13b7 100644 --- a/panda/src/event/eventQueue.cxx +++ b/panda/src/event/eventQueue.cxx @@ -45,6 +45,11 @@ EventQueue:: void EventQueue:: queue_event(CPT_Event event) { nassertv(!event.is_null()); + if (event->get_name().empty()) { + // Never mind. + return; + } + MutexHolder holder(_lock); _queue.push_back(event); diff --git a/panda/src/event/throw_event.I b/panda/src/event/throw_event.I index 63ddec4269..70a0d76ecb 100644 --- a/panda/src/event/throw_event.I +++ b/panda/src/event/throw_event.I @@ -53,6 +53,20 @@ throw_event(const string &event_name, EventQueue::get_global_event_queue()->queue_event(event); } +INLINE void +throw_event(const string &event_name, + const EventParameter &p1, + const EventParameter &p2, + const EventParameter &p3, + const EventParameter &p4) { + Event *event = new Event(event_name); + event->add_parameter(p1); + event->add_parameter(p2); + event->add_parameter(p3); + event->add_parameter(p4); + EventQueue::get_global_event_queue()->queue_event(event); +} + //////////////////////////////////////////////////////////////////////////// INLINE void diff --git a/panda/src/event/throw_event.h b/panda/src/event/throw_event.h index d6d6883344..564a4acfd4 100644 --- a/panda/src/event/throw_event.h +++ b/panda/src/event/throw_event.h @@ -33,6 +33,11 @@ INLINE void throw_event(const string &event_name, const EventParameter &p1, const EventParameter &p2, const EventParameter &p3); +INLINE void throw_event(const string &event_name, + const EventParameter &p1, + const EventParameter &p2, + const EventParameter &p3, + const EventParameter &p4); #include "eventHandler.h" diff --git a/panda/src/pgraph/billboardEffect.cxx b/panda/src/pgraph/billboardEffect.cxx index d8f56b0649..dcbe6fdd59 100644 --- a/panda/src/pgraph/billboardEffect.cxx +++ b/panda/src/pgraph/billboardEffect.cxx @@ -278,6 +278,11 @@ compute_billboard(CPT(TransformState) &node_transform, CPT(TransformState) rel_transform = net_transform->compose(translate)->invert_compose(camera_transform); + if (!rel_transform->has_mat()) { + // Never mind. + return; + } + const LMatrix4f &rel_mat = rel_transform->get_mat(); // Determine the look_at point in the camera space. diff --git a/panda/src/putil/bam.h b/panda/src/putil/bam.h index fe98951b08..7abdbd00f6 100644 --- a/panda/src/putil/bam.h +++ b/panda/src/putil/bam.h @@ -49,6 +49,7 @@ static const unsigned short _bam_minor_ver = 16; // Bumped to minor version 14 on 12/19/07 to change default ColorAttrib. // Bumped to minor version 15 on 4/9/08 to add TextureAttrib::_implicit_sort. // Bumped to minor version 16 on 5/13/08 to add Texture::_quality_level. +// Bumped to minor version 17 on 8/6/08 to add PartBundle::_anim_preload. #endif diff --git a/panda/src/putil/bamReader.cxx b/panda/src/putil/bamReader.cxx index 294a33dbe9..6435650894 100644 --- a/panda/src/putil/bamReader.cxx +++ b/panda/src/putil/bamReader.cxx @@ -540,6 +540,8 @@ read_handle(DatagramIterator &scan) { //////////////////////////////////////////////////////////////////// void BamReader:: read_pointer(DatagramIterator &scan) { + Thread::consider_yield(); + nassertv(_now_creating != _created_objs.end()); int requestor_id = (*_now_creating).first;