1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015 |
- /* A Bison parser, made from omparser.y
- by GNU Bison version 1.28 */
- #define YYBISON 1 /* Identify Bison output. */
- #define OM_YYERROR 257
- #define OM_INT 258
- #define OM_FLOAT 259
- #define OM_BYTEARRAY 260
- #define OM_VAR 261
- #define OM_STRING 262
- #define OM_SYMBOL 263
- #define OM_APP 264
- #define OM_ENDAPP 265
- #define OM_ATP 266
- #define OM_ENDATP 267
- #define OM_ATTR 268
- #define OM_ENDATTR 269
- #define OM_BIND 270
- #define OM_ENDBIND 271
- #define OM_BVAR 272
- #define OM_ENDBVAR 273
- #define OM_ERROR 274
- #define OM_ENDERROR 275
- #define OM_OBJECT 276
- #define OM_ENDOBJECT 277
- #define OM_SYM_alg1_zero 278
- #define OM_SYM_alg1_one 279
- #define OM_SYM_arith1_abs 280
- #define OM_SYM_arith1_divide 281
- #define OM_SYM_arith1_gcd 282
- #define OM_SYM_arith1_lcm 283
- #define OM_SYM_arith1_minus 284
- #define OM_SYM_arith1_plus 285
- #define OM_SYM_arith1_power 286
- #define OM_SYM_arith1_product 287
- #define OM_SYM_arith1_root 288
- #define OM_SYM_arith1_sum 289
- #define OM_SYM_arith1_times 290
- #define OM_SYM_arith1_unary_minus 291
- #define OM_SYM_arith2_arg 292
- #define OM_SYM_arith2_inverse 293
- #define OM_SYM_arith2_times 294
- #define OM_SYM_bigfloat1_bigfloat 295
- #define OM_SYM_calculus1_defint 296
- #define OM_SYM_calculus1_diff 297
- #define OM_SYM_calculus1_int 298
- #define OM_SYM_calculus1_partialdiff 299
- #define OM_SYM_complex1_argument 300
- #define OM_SYM_complex1_complex_cartesian 301
- #define OM_SYM_complex1_complex_polar 302
- #define OM_SYM_complex1_conjugate 303
- #define OM_SYM_complex1_imaginary 304
- #define OM_SYM_complex1_real 305
- #define OM_SYM_fns1_domain 306
- #define OM_SYM_fns1_range 307
- #define OM_SYM_fns1_image 308
- #define OM_SYM_fns1_identity 309
- #define OM_SYM_fns1_inverse 310
- #define OM_SYM_fns1_lambda 311
- #define OM_SYM_fns1_left_compose 312
- #define OM_SYM_fns2_apply_to_list 313
- #define OM_SYM_fns2_kernel 314
- #define OM_SYM_fns2_right_compose 315
- #define OM_SYM_integer1_factorial 316
- #define OM_SYM_integer1_factorof 317
- #define OM_SYM_integer1_quotient 318
- #define OM_SYM_integer1_remainder 319
- #define OM_SYM_interval1_integer_interval 320
- #define OM_SYM_interval1_interval 321
- #define OM_SYM_interval1_interval_cc 322
- #define OM_SYM_interval1_interval_co 323
- #define OM_SYM_interval1_interval_oc 324
- #define OM_SYM_interval1_interval_oo 325
- #define OM_SYM_limit1_above 326
- #define OM_SYM_limit1_below 327
- #define OM_SYM_limit1_both_sides 328
- #define OM_SYM_limit1_limit 329
- #define OM_SYM_limit1_null 330
- #define OM_SYM_linalg1_determinant 331
- #define OM_SYM_linalg1_matrix_selector 332
- #define OM_SYM_linalg1_vector_selector 333
- #define OM_SYM_linalg1_transpose 334
- #define OM_SYM_linalg1_outerproduct 335
- #define OM_SYM_linalg1_scalarproduct 336
- #define OM_SYM_linalg1_vectorproduct 337
- #define OM_SYM_linalg2_matrix 338
- #define OM_SYM_linalg2_matrixrow 339
- #define OM_SYM_linalg2_vector 340
- #define OM_SYM_linalg3_matrix 341
- #define OM_SYM_linalg3_matrixcolumn 342
- #define OM_SYM_linalg3_vector 343
- #define OM_SYM_list1_list 344
- #define OM_SYM_list1_map 345
- #define OM_SYM_list1_suchthat 346
- #define OM_SYM_list2_cons 347
- #define OM_SYM_list2_first 348
- #define OM_SYM_list2_rest 349
- #define OM_SYM_logic1_and 350
- #define OM_SYM_logic1_false 351
- #define OM_SYM_logic1_implies 352
- #define OM_SYM_logic1_not 353
- #define OM_SYM_logic1_or 354
- #define OM_SYM_logic1_true 355
- #define OM_SYM_logic1_xor 356
- #define OM_SYM_logic1_equivalent 357
- #define OM_SYM_minmax1_max 358
- #define OM_SYM_minmax1_min 359
- #define OM_SYM_nums1_based_integer 360
- #define OM_SYM_nums1_e 361
- #define OM_SYM_nums1_gamma 362
- #define OM_SYM_nums1_i 363
- #define OM_SYM_nums1_infinity 364
- #define OM_SYM_nums1_NaN 365
- #define OM_SYM_nums1_pi 366
- #define OM_SYM_nums1_rational 367
- #define OM_SYM_relation1_eq 368
- #define OM_SYM_relation1_geq 369
- #define OM_SYM_relation1_gt 370
- #define OM_SYM_relation1_leq 371
- #define OM_SYM_relation1_lt 372
- #define OM_SYM_relation1_neq 373
- #define OM_SYM_relation1_approx 374
- #define OM_SYM_rounding1_ceiling 375
- #define OM_SYM_rounding1_floor 376
- #define OM_SYM_rounding1_trunc 377
- #define OM_SYM_rounding1_round 378
- #define OM_SYM_setname1_C 379
- #define OM_SYM_setname1_N 380
- #define OM_SYM_setname1_P 381
- #define OM_SYM_setname1_Q 382
- #define OM_SYM_setname1_R 383
- #define OM_SYM_setname1_Z 384
- #define OM_SYM_set1_cartesian_product 385
- #define OM_SYM_set1_emptyset 386
- #define OM_SYM_set1_in 387
- #define OM_SYM_set1_intersect 388
- #define OM_SYM_set1_map 389
- #define OM_SYM_set1_notin 390
- #define OM_SYM_set1_notprsubset 391
- #define OM_SYM_set1_notsubset 392
- #define OM_SYM_set1_prsubset 393
- #define OM_SYM_set1_set 394
- #define OM_SYM_set1_setdiff 395
- #define OM_SYM_set1_size 396
- #define OM_SYM_set1_subset 397
- #define OM_SYM_set1_suchthat 398
- #define OM_SYM_set1_union 399
- #define OM_SYM_transc1_arccos 400
- #define OM_SYM_transc1_arcsin 401
- #define OM_SYM_transc1_arctan 402
- #define OM_SYM_transc1_cos 403
- #define OM_SYM_transc1_cosh 404
- #define OM_SYM_transc1_cot 405
- #define OM_SYM_transc1_coth 406
- #define OM_SYM_transc1_csc 407
- #define OM_SYM_transc1_csch 408
- #define OM_SYM_transc1_exp 409
- #define OM_SYM_transc1_ln 410
- #define OM_SYM_transc1_log 411
- #define OM_SYM_transc1_sec 412
- #define OM_SYM_transc1_sech 413
- #define OM_SYM_transc1_sin 414
- #define OM_SYM_transc1_sinh 415
- #define OM_SYM_transc1_tan 416
- #define OM_SYM_transc1_tanh 417
- #define OM_SYM_transc1_arccosh 418
- #define OM_SYM_transc1_arccot 419
- #define OM_SYM_transc1_arccoth 420
- #define OM_SYM_transc1_arccsc 421
- #define OM_SYM_transc1_arccsch 422
- #define OM_SYM_transc1_arcsec 423
- #define OM_SYM_transc1_arcsech 424
- #define OM_SYM_transc1_arcsinh 425
- #define OM_SYM_transc1_arctanh 426
- #line 1 "omparser.y"
- #include <assert.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include <stdarg.h>
- #include <string.h>
- #include <math.h>
- #include <float.h>
- #include <malloc.h>
- #include "machine.h"
- #include "tags.h"
- #include "cslerror.h"
- #include "externs.h"
- #include "entries.h"
- #include "arith.h"
- #include "read.h"
- #include <OM.h>
- #include <OMconn.h>
- #include "openmath.h"
- #define YYSTYPE Lisp_Object
- #define StrToLspM(S) qcar(Lmv_list(C_nil, Lintern(C_nil, make_string(S))))
- #define MkUndefSymM(x) make_undefined_symbol(x)
- /* Enable parser debugging. */
- #define YYDEBUG 0
- /* Prototypes for required parser interface functions. */
- int yyerror(char *);
- YYSTYPE yylex();
- /*
- * External CCL functions.
- */
- extern char *get_string_data(Lisp_Object name, char *why, int32 *l);
- /* Some global variables (yuk!). */
- static Lisp_Object ldev;
- static Lisp_Object inObj;
- /* End of preamble. */
- #ifndef YYSTYPE
- #define YYSTYPE int
- #endif
- #include <stdio.h>
- #ifndef __cplusplus
- #ifndef __STDC__
- #define const
- #endif
- #endif
- #define YYFINAL 649
- #define YYFLAG -32768
- #define YYNTBASE 173
- #define YYTRANSLATE(x) ((unsigned)(x) <= 426 ? yytranslate[x] : 251)
- static const short 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, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 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, 92, 93, 94, 95, 96,
- 97, 98, 99, 100, 101, 102, 103, 104, 105, 106,
- 107, 108, 109, 110, 111, 112, 113, 114, 115, 116,
- 117, 118, 119, 120, 121, 122, 123, 124, 125, 126,
- 127, 128, 129, 130, 131, 132, 133, 134, 135, 136,
- 137, 138, 139, 140, 141, 142, 143, 144, 145, 146,
- 147, 148, 149, 150, 151, 152, 153, 154, 155, 156,
- 157, 158, 159, 160, 161, 162, 163, 164, 165, 166,
- 167, 168, 169, 170, 171, 172
- };
- #if YYDEBUG != 0
- static const short yyprhs[] = { 0,
- 0, 4, 5, 9, 10, 13, 15, 17, 19, 21,
- 23, 25, 27, 29, 31, 38, 40, 47, 49, 56,
- 58, 65, 67, 74, 76, 83, 85, 87, 89, 91,
- 93, 95, 97, 99, 101, 103, 105, 107, 109, 111,
- 113, 115, 117, 119, 121, 123, 125, 127, 129, 131,
- 133, 135, 137, 139, 141, 143, 145, 147, 149, 151,
- 153, 155, 157, 159, 161, 163, 165, 167, 169, 171,
- 173, 175, 177, 179, 181, 183, 185, 187, 189, 191,
- 193, 195, 197, 199, 201, 203, 205, 207, 209, 211,
- 213, 215, 217, 219, 221, 223, 225, 227, 229, 231,
- 233, 235, 237, 239, 241, 243, 245, 247, 249, 251,
- 253, 255, 257, 259, 261, 263, 265, 267, 269, 271,
- 273, 275, 277, 279, 281, 283, 285, 287, 289, 291,
- 293, 295, 297, 299, 301, 303, 305, 307, 309, 311,
- 313, 315, 317, 319, 321, 323, 325, 327, 329, 331,
- 333, 335, 337, 339, 341, 343, 345, 347, 349, 351,
- 353, 355, 357, 359, 361, 363, 365, 367, 369, 371,
- 373, 375, 377, 379, 381, 383, 385, 387, 389, 391,
- 393, 395, 397, 399, 401, 403, 405, 407, 409, 411,
- 413, 415, 417, 419, 421, 423, 425, 427, 429, 431,
- 432, 435, 437, 439, 441, 449, 453, 462, 464, 466,
- 468, 470, 472, 474, 476, 478, 480, 482, 484, 486,
- 488, 490, 492, 494, 496, 498, 500, 502, 504, 506,
- 508, 510, 512, 514, 517, 521, 524, 527, 531, 533,
- 536, 540, 544, 548, 552, 554, 557, 560, 562, 565,
- 567, 570, 573, 576, 578, 581, 586, 590, 593, 596,
- 600, 606, 612, 614, 616, 618, 620, 622, 630, 633,
- 637, 641, 644, 647, 650, 653, 656, 659, 662, 665,
- 669, 673, 676, 680, 683, 687, 691, 695, 699, 703,
- 707, 711, 715, 719, 724, 729, 734, 739, 742, 745,
- 748, 749, 755, 758, 761, 764, 765, 771, 774, 779,
- 783, 786, 790, 794, 798, 801, 805, 809, 811, 813,
- 815, 817, 824, 832, 836, 839, 842, 844, 847, 849,
- 853, 856, 858, 861, 863, 865, 868, 872, 874, 877,
- 879, 882, 884, 887, 889, 892, 894, 897, 899, 902,
- 904, 907, 911, 915, 919, 923, 927, 931, 935, 939,
- 943, 946, 949, 952, 955, 959, 963, 967, 971, 975,
- 979, 982, 986, 990, 994, 997, 1000, 1002, 1006, 1010,
- 1013, 1016, 1019, 1022, 1025, 1028, 1031, 1034, 1037, 1040,
- 1043, 1047, 1050, 1053, 1056, 1059, 1062, 1065, 1068, 1071,
- 1074, 1077, 1080, 1083, 1086, 1089, 1092, 1095, 1099, 1108,
- 1110
- };
- static const short yyrhs[] = { 22,
- 176, 23, 0, 0, 183, 176, 174, 0, 0, 180,
- 175, 0, 177, 0, 178, 0, 179, 0, 180, 0,
- 181, 0, 182, 0, 210, 0, 248, 0, 4, 0,
- 14, 12, 174, 13, 4, 15, 0, 5, 0, 14,
- 12, 174, 13, 5, 15, 0, 6, 0, 14, 12,
- 174, 13, 6, 15, 0, 7, 0, 14, 12, 174,
- 13, 7, 15, 0, 8, 0, 14, 12, 174, 13,
- 8, 15, 0, 183, 0, 14, 12, 174, 13, 183,
- 15, 0, 9, 0, 184, 0, 185, 0, 186, 0,
- 187, 0, 188, 0, 189, 0, 190, 0, 191, 0,
- 192, 0, 193, 0, 194, 0, 197, 0, 195, 0,
- 196, 0, 198, 0, 199, 0, 200, 0, 201, 0,
- 202, 0, 203, 0, 204, 0, 205, 0, 206, 0,
- 207, 0, 24, 0, 25, 0, 26, 0, 27, 0,
- 28, 0, 29, 0, 30, 0, 31, 0, 32, 0,
- 33, 0, 34, 0, 35, 0, 36, 0, 37, 0,
- 38, 0, 39, 0, 40, 0, 41, 0, 42, 0,
- 43, 0, 44, 0, 45, 0, 46, 0, 47, 0,
- 48, 0, 49, 0, 50, 0, 51, 0, 55, 0,
- 56, 0, 57, 0, 58, 0, 52, 0, 53, 0,
- 54, 0, 59, 0, 60, 0, 61, 0, 62, 0,
- 63, 0, 64, 0, 65, 0, 66, 0, 67, 0,
- 68, 0, 69, 0, 70, 0, 71, 0, 72, 0,
- 73, 0, 74, 0, 75, 0, 76, 0, 84, 0,
- 85, 0, 86, 0, 87, 0, 88, 0, 89, 0,
- 77, 0, 78, 0, 79, 0, 80, 0, 81, 0,
- 82, 0, 83, 0, 90, 0, 91, 0, 92, 0,
- 93, 0, 94, 0, 95, 0, 96, 0, 97, 0,
- 98, 0, 99, 0, 100, 0, 101, 0, 102, 0,
- 103, 0, 104, 0, 105, 0, 106, 0, 107, 0,
- 108, 0, 109, 0, 110, 0, 111, 0, 112, 0,
- 113, 0, 114, 0, 115, 0, 116, 0, 117, 0,
- 118, 0, 119, 0, 120, 0, 121, 0, 122, 0,
- 123, 0, 124, 0, 125, 0, 126, 0, 127, 0,
- 128, 0, 129, 0, 130, 0, 131, 0, 132, 0,
- 135, 0, 142, 0, 144, 0, 133, 0, 134, 0,
- 136, 0, 137, 0, 138, 0, 139, 0, 140, 0,
- 141, 0, 143, 0, 145, 0, 146, 0, 147, 0,
- 148, 0, 149, 0, 150, 0, 151, 0, 152, 0,
- 153, 0, 154, 0, 155, 0, 156, 0, 157, 0,
- 158, 0, 159, 0, 160, 0, 161, 0, 162, 0,
- 163, 0, 164, 0, 165, 0, 166, 0, 167, 0,
- 168, 0, 169, 0, 170, 0, 171, 0, 172, 0,
- 0, 176, 208, 0, 180, 0, 182, 0, 210, 0,
- 16, 57, 18, 180, 19, 176, 17, 0, 10, 211,
- 11, 0, 14, 12, 174, 13, 10, 211, 11, 15,
- 0, 212, 0, 213, 0, 216, 0, 217, 0, 218,
- 0, 222, 0, 223, 0, 224, 0, 225, 0, 226,
- 0, 227, 0, 232, 0, 228, 0, 230, 0, 233,
- 0, 234, 0, 235, 0, 239, 0, 242, 0, 243,
- 0, 244, 0, 245, 0, 246, 0, 247, 0, 24,
- 0, 25, 0, 26, 176, 0, 27, 176, 176, 0,
- 28, 208, 0, 29, 208, 0, 30, 176, 176, 0,
- 31, 0, 31, 214, 0, 32, 176, 176, 0, 33,
- 176, 176, 0, 34, 176, 176, 0, 35, 176, 176,
- 0, 36, 0, 36, 215, 0, 37, 176, 0, 176,
- 0, 176, 214, 0, 176, 0, 176, 215, 0, 38,
- 176, 0, 39, 176, 0, 40, 0, 40, 215, 0,
- 41, 176, 176, 176, 0, 42, 219, 209, 0, 43,
- 209, 0, 44, 209, 0, 45, 176, 221, 0, 10,
- 66, 176, 176, 11, 0, 10, 220, 176, 176, 11,
- 0, 67, 0, 67, 0, 67, 0, 67, 0, 67,
- 0, 16, 57, 18, 175, 19, 176, 17, 0, 46,
- 176, 0, 47, 176, 176, 0, 48, 176, 176, 0,
- 49, 176, 0, 50, 176, 0, 51, 176, 0, 55,
- 176, 0, 56, 176, 0, 54, 176, 0, 53, 176,
- 0, 52, 176, 0, 58, 209, 209, 0, 59, 209,
- 176, 0, 60, 209, 0, 61, 209, 209, 0, 62,
- 176, 0, 63, 176, 176, 0, 64, 176, 176, 0,
- 65, 176, 176, 0, 66, 176, 176, 0, 67, 176,
- 176, 0, 68, 176, 176, 0, 69, 176, 176, 0,
- 70, 176, 176, 0, 71, 176, 176, 0, 75, 176,
- 72, 209, 0, 75, 176, 73, 209, 0, 75, 176,
- 74, 209, 0, 75, 176, 76, 209, 0, 84, 229,
- 0, 85, 208, 0, 86, 208, 0, 0, 10, 85,
- 208, 11, 229, 0, 87, 231, 0, 88, 208, 0,
- 89, 208, 0, 0, 10, 88, 208, 11, 231, 0,
- 77, 176, 0, 78, 176, 176, 176, 0, 79, 176,
- 176, 0, 80, 176, 0, 81, 176, 176, 0, 82,
- 176, 176, 0, 83, 176, 176, 0, 90, 208, 0,
- 91, 176, 176, 0, 92, 176, 176, 0, 180, 0,
- 182, 0, 210, 0, 0, 0, 14, 12, 174, 13,
- 0, 15, 0, 16, 57, 18, 180, 19, 176, 17,
- 0, 93, 176, 176, 0, 94, 176, 0, 95, 176,
- 0, 96, 0, 96, 236, 0, 97, 0, 98, 176,
- 176, 0, 99, 176, 0, 100, 0, 100, 237, 0,
- 101, 0, 102, 0, 102, 238, 0, 103, 176, 176,
- 0, 176, 0, 176, 236, 0, 176, 0, 176, 237,
- 0, 176, 0, 176, 238, 0, 104, 0, 104, 240,
- 0, 105, 0, 105, 241, 0, 176, 0, 176, 240,
- 0, 176, 0, 176, 241, 0, 106, 176, 176, 0,
- 113, 176, 176, 0, 114, 176, 176, 0, 115, 176,
- 176, 0, 116, 176, 176, 0, 117, 176, 176, 0,
- 118, 176, 176, 0, 119, 176, 176, 0, 120, 176,
- 176, 0, 121, 176, 0, 122, 176, 0, 123, 176,
- 0, 124, 176, 0, 133, 176, 176, 0, 134, 176,
- 176, 0, 136, 176, 176, 0, 137, 176, 176, 0,
- 138, 176, 176, 0, 139, 176, 176, 0, 140, 208,
- 0, 141, 176, 176, 0, 143, 176, 176, 0, 145,
- 176, 176, 0, 142, 176, 0, 131, 208, 0, 132,
- 0, 135, 176, 176, 0, 144, 176, 176, 0, 146,
- 176, 0, 147, 176, 0, 148, 176, 0, 149, 176,
- 0, 150, 176, 0, 151, 176, 0, 152, 176, 0,
- 153, 176, 0, 154, 176, 0, 155, 176, 0, 156,
- 176, 0, 157, 176, 176, 0, 158, 176, 0, 159,
- 176, 0, 160, 176, 0, 161, 176, 0, 162, 176,
- 0, 163, 176, 0, 164, 176, 0, 165, 176, 0,
- 166, 176, 0, 167, 176, 0, 168, 176, 0, 169,
- 176, 0, 170, 176, 0, 171, 176, 0, 172, 176,
- 0, 248, 208, 0, 16, 249, 17, 0, 14, 12,
- 174, 13, 16, 249, 17, 15, 0, 250, 0, 57,
- 18, 175, 19, 176, 0
- };
- #endif
- #if YYDEBUG != 0
- static const short yyrline[] = { 0,
- 296, 301, 303, 307, 310, 314, 316, 317, 318, 319,
- 320, 321, 322, 326, 329, 333, 336, 340, 343, 347,
- 350, 354, 357, 361, 364, 368, 370, 371, 372, 373,
- 374, 375, 376, 377, 378, 379, 380, 381, 382, 383,
- 384, 385, 386, 387, 388, 389, 390, 391, 392, 393,
- 396, 398, 401, 403, 404, 405, 406, 407, 408, 409,
- 410, 411, 412, 413, 416, 418, 419, 422, 426, 428,
- 429, 430, 433, 435, 436, 437, 438, 439, 442, 444,
- 445, 446, 447, 448, 449, 452, 454, 455, 458, 460,
- 461, 462, 465, 467, 468, 469, 470, 471, 474, 476,
- 477, 478, 479, 482, 484, 485, 488, 490, 491, 494,
- 496, 497, 498, 499, 500, 501, 504, 506, 507, 510,
- 512, 513, 516, 518, 519, 520, 521, 522, 523, 524,
- 527, 529, 532, 534, 535, 536, 537, 538, 539, 540,
- 543, 545, 546, 547, 548, 549, 550, 553, 555, 556,
- 557, 560, 562, 563, 564, 565, 566, 569, 571, 572,
- 573, 574, 575, 576, 577, 578, 579, 580, 581, 582,
- 583, 584, 587, 589, 590, 591, 592, 593, 594, 595,
- 596, 597, 598, 599, 600, 601, 602, 603, 604, 605,
- 606, 607, 608, 609, 610, 611, 612, 613, 614, 618,
- 621, 626, 635, 643, 651, 659, 662, 666, 668, 669,
- 670, 671, 672, 673, 674, 675, 676, 677, 678, 679,
- 680, 681, 682, 683, 684, 685, 686, 687, 688, 689,
- 690, 693, 696, 700, 706, 711, 716, 721, 726, 728,
- 730, 735, 740, 745, 750, 752, 754, 761, 764, 772,
- 775, 783, 789, 794, 796, 802, 810, 826, 828, 834,
- 882, 889, 903, 905, 906, 907, 908, 913, 921, 927,
- 932, 938, 943, 948, 957, 960, 962, 967, 972, 977,
- 1006, 1012, 1014, 1043, 1049, 1054, 1059, 1066, 1072, 1082,
- 1092, 1113, 1134, 1158, 1180, 1201, 1222, 1245, 1252, 1254,
- 1258, 1261, 1265, 1273, 1275, 1279, 1282, 1286, 1292, 1294,
- 1299, 1304, 1309, 1314, 1321, 1324, 1329, 1340, 1349, 1357,
- 1365, 1367, 1371, 1380, 1386, 1391, 1398, 1401, 1403, 1405,
- 1410, 1415, 1417, 1419, 1421, 1423, 1425, 1429, 1432, 1440,
- 1443, 1451, 1454, 1462, 1465, 1467, 1469, 1473, 1476, 1484,
- 1487, 1497, 1500, 1515, 1526, 1531, 1536, 1541, 1546, 1551,
- 1558, 1564, 1569, 1574, 1581, 1587, 1592, 1598, 1604, 1610,
- 1615, 1619, 1624, 1629, 1634, 1639, 1644, 1649, 1654, 1662,
- 1668, 1673, 1678, 1683, 1688, 1693, 1698, 1703, 1708, 1713,
- 1718, 1724, 1729, 1734, 1739, 1744, 1749, 1754, 1759, 1764,
- 1769, 1774, 1779, 1784, 1789, 1794, 1801, 1806, 1809, 1813,
- 1817
- };
- #endif
- #if YYDEBUG != 0 || defined (YYERROR_VERBOSE)
- static const char * const yytname[] = { "$","error","$undefined.","OM_YYERROR",
- "OM_INT","OM_FLOAT","OM_BYTEARRAY","OM_VAR","OM_STRING","OM_SYMBOL","OM_APP",
- "OM_ENDAPP","OM_ATP","OM_ENDATP","OM_ATTR","OM_ENDATTR","OM_BIND","OM_ENDBIND",
- "OM_BVAR","OM_ENDBVAR","OM_ERROR","OM_ENDERROR","OM_OBJECT","OM_ENDOBJECT","OM_SYM_alg1_zero",
- "OM_SYM_alg1_one","OM_SYM_arith1_abs","OM_SYM_arith1_divide","OM_SYM_arith1_gcd",
- "OM_SYM_arith1_lcm","OM_SYM_arith1_minus","OM_SYM_arith1_plus","OM_SYM_arith1_power",
- "OM_SYM_arith1_product","OM_SYM_arith1_root","OM_SYM_arith1_sum","OM_SYM_arith1_times",
- "OM_SYM_arith1_unary_minus","OM_SYM_arith2_arg","OM_SYM_arith2_inverse","OM_SYM_arith2_times",
- "OM_SYM_bigfloat1_bigfloat","OM_SYM_calculus1_defint","OM_SYM_calculus1_diff",
- "OM_SYM_calculus1_int","OM_SYM_calculus1_partialdiff","OM_SYM_complex1_argument",
- "OM_SYM_complex1_complex_cartesian","OM_SYM_complex1_complex_polar","OM_SYM_complex1_conjugate",
- "OM_SYM_complex1_imaginary","OM_SYM_complex1_real","OM_SYM_fns1_domain","OM_SYM_fns1_range",
- "OM_SYM_fns1_image","OM_SYM_fns1_identity","OM_SYM_fns1_inverse","OM_SYM_fns1_lambda",
- "OM_SYM_fns1_left_compose","OM_SYM_fns2_apply_to_list","OM_SYM_fns2_kernel",
- "OM_SYM_fns2_right_compose","OM_SYM_integer1_factorial","OM_SYM_integer1_factorof",
- "OM_SYM_integer1_quotient","OM_SYM_integer1_remainder","OM_SYM_interval1_integer_interval",
- "OM_SYM_interval1_interval","OM_SYM_interval1_interval_cc","OM_SYM_interval1_interval_co",
- "OM_SYM_interval1_interval_oc","OM_SYM_interval1_interval_oo","OM_SYM_limit1_above",
- "OM_SYM_limit1_below","OM_SYM_limit1_both_sides","OM_SYM_limit1_limit","OM_SYM_limit1_null",
- "OM_SYM_linalg1_determinant","OM_SYM_linalg1_matrix_selector","OM_SYM_linalg1_vector_selector",
- "OM_SYM_linalg1_transpose","OM_SYM_linalg1_outerproduct","OM_SYM_linalg1_scalarproduct",
- "OM_SYM_linalg1_vectorproduct","OM_SYM_linalg2_matrix","OM_SYM_linalg2_matrixrow",
- "OM_SYM_linalg2_vector","OM_SYM_linalg3_matrix","OM_SYM_linalg3_matrixcolumn",
- "OM_SYM_linalg3_vector","OM_SYM_list1_list","OM_SYM_list1_map","OM_SYM_list1_suchthat",
- "OM_SYM_list2_cons","OM_SYM_list2_first","OM_SYM_list2_rest","OM_SYM_logic1_and",
- "OM_SYM_logic1_false","OM_SYM_logic1_implies","OM_SYM_logic1_not","OM_SYM_logic1_or",
- "OM_SYM_logic1_true","OM_SYM_logic1_xor","OM_SYM_logic1_equivalent","OM_SYM_minmax1_max",
- "OM_SYM_minmax1_min","OM_SYM_nums1_based_integer","OM_SYM_nums1_e","OM_SYM_nums1_gamma",
- "OM_SYM_nums1_i","OM_SYM_nums1_infinity","OM_SYM_nums1_NaN","OM_SYM_nums1_pi",
- "OM_SYM_nums1_rational","OM_SYM_relation1_eq","OM_SYM_relation1_geq","OM_SYM_relation1_gt",
- "OM_SYM_relation1_leq","OM_SYM_relation1_lt","OM_SYM_relation1_neq","OM_SYM_relation1_approx",
- "OM_SYM_rounding1_ceiling","OM_SYM_rounding1_floor","OM_SYM_rounding1_trunc",
- "OM_SYM_rounding1_round","OM_SYM_setname1_C","OM_SYM_setname1_N","OM_SYM_setname1_P",
- "OM_SYM_setname1_Q","OM_SYM_setname1_R","OM_SYM_setname1_Z","OM_SYM_set1_cartesian_product",
- "OM_SYM_set1_emptyset","OM_SYM_set1_in","OM_SYM_set1_intersect","OM_SYM_set1_map",
- "OM_SYM_set1_notin","OM_SYM_set1_notprsubset","OM_SYM_set1_notsubset","OM_SYM_set1_prsubset",
- "OM_SYM_set1_set","OM_SYM_set1_setdiff","OM_SYM_set1_size","OM_SYM_set1_subset",
- "OM_SYM_set1_suchthat","OM_SYM_set1_union","OM_SYM_transc1_arccos","OM_SYM_transc1_arcsin",
- "OM_SYM_transc1_arctan","OM_SYM_transc1_cos","OM_SYM_transc1_cosh","OM_SYM_transc1_cot",
- "OM_SYM_transc1_coth","OM_SYM_transc1_csc","OM_SYM_transc1_csch","OM_SYM_transc1_exp",
- "OM_SYM_transc1_ln","OM_SYM_transc1_log","OM_SYM_transc1_sec","OM_SYM_transc1_sech",
- "OM_SYM_transc1_sin","OM_SYM_transc1_sinh","OM_SYM_transc1_tan","OM_SYM_transc1_tanh",
- "OM_SYM_transc1_arccosh","OM_SYM_transc1_arccot","OM_SYM_transc1_arccoth","OM_SYM_transc1_arccsc",
- "OM_SYM_transc1_arccsch","OM_SYM_transc1_arcsec","OM_SYM_transc1_arcsech","OM_SYM_transc1_arcsinh",
- "OM_SYM_transc1_arctanh","om_whole_object","om_attributes","om_variables","om_object",
- "om_integer","om_float","om_bytearray","om_variable","om_string","om_symbol",
- "om_symbol_inner","om_alg1_symbol","om_arith1_symbol","om_arith2_symbol","om_bigfloat1_symbol",
- "om_calculus1_symbol","om_complex1_symbol","om_fns1_symbol","om_fns2_symbol",
- "om_integer1_symbol","om_interval1_symbol","om_limit1_symbol","om_linalg2_symbol",
- "om_linalg3_symbol","om_linalg1_symbol","om_list1_symbol","om_list2_symbol",
- "om_logic1_symbol","om_minmax1_symbol","om_nums1_symbol","om_relation1_symbol",
- "om_rounding1_symbol","om_setname1_symbol","om_set1_symbol","om_transc1_symbol",
- "om_nary_args","om_unary_func","om_apply","om_apply_inner","om_apply_alg1_inner",
- "om_apply_arith1_inner","om_arith1_plus_args","om_arith1_times_args","om_apply_arith2_inner",
- "om_apply_bigfloat1_inner","om_apply_calculus1_inner","om_calculus1_interval",
- "om_calculus1_interval_symbol","om_calculus1_partialdiff_funcarg","om_apply_complex1_inner",
- "om_apply_fns1_inner","om_apply_fns2_inner","om_apply_integer1_inner","om_apply_interval1_inner",
- "om_apply_limit1_inner","om_apply_linalg2_inner","om_linalg2_matrix_args","om_apply_linalg3_inner",
- "om_linalg3_matrix_args","om_apply_linalg1_inner","om_apply_list1_inner","om_apply_list2_inner",
- "om_apply_logic1_inner","om_logic1_and_args","om_logic1_or_args","om_logic1_xor_args",
- "om_apply_minmax1_inner","om_minmax1_max_args","om_minmax1_min_args","om_apply_nums1_inner",
- "om_apply_relation1_inner","om_apply_rounding1_inner","om_apply_set1_inner",
- "om_apply_transc1_inner","om_apply_boundexpr_inner","om_bind","om_bind_inner",
- "om_bind_fns1_inner", NULL
- };
- #endif
- static const short yyr1[] = { 0,
- 173, 174, 174, 175, 175, 176, 176, 176, 176, 176,
- 176, 176, 176, 177, 177, 178, 178, 179, 179, 180,
- 180, 181, 181, 182, 182, 183, 183, 183, 183, 183,
- 183, 183, 183, 183, 183, 183, 183, 183, 183, 183,
- 183, 183, 183, 183, 183, 183, 183, 183, 183, 183,
- 184, 184, 185, 185, 185, 185, 185, 185, 185, 185,
- 185, 185, 185, 185, 186, 186, 186, 187, 188, 188,
- 188, 188, 189, 189, 189, 189, 189, 189, 190, 190,
- 190, 190, 190, 190, 190, 191, 191, 191, 192, 192,
- 192, 192, 193, 193, 193, 193, 193, 193, 194, 194,
- 194, 194, 194, 195, 195, 195, 196, 196, 196, 197,
- 197, 197, 197, 197, 197, 197, 198, 198, 198, 199,
- 199, 199, 200, 200, 200, 200, 200, 200, 200, 200,
- 201, 201, 202, 202, 202, 202, 202, 202, 202, 202,
- 203, 203, 203, 203, 203, 203, 203, 204, 204, 204,
- 204, 205, 205, 205, 205, 205, 205, 206, 206, 206,
- 206, 206, 206, 206, 206, 206, 206, 206, 206, 206,
- 206, 206, 207, 207, 207, 207, 207, 207, 207, 207,
- 207, 207, 207, 207, 207, 207, 207, 207, 207, 207,
- 207, 207, 207, 207, 207, 207, 207, 207, 207, 208,
- 208, 209, 209, 209, 209, 210, 210, 211, 211, 211,
- 211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
- 211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
- 211, 212, 212, 213, 213, 213, 213, 213, 213, 213,
- 213, 213, 213, 213, 213, 213, 213, 214, 214, 215,
- 215, 216, 216, 216, 216, 217, 218, 218, 218, 218,
- 219, 219, 220, 220, 220, 220, 220, 221, 222, 222,
- 222, 222, 222, 222, 223, 223, 223, 223, 223, 223,
- 224, 224, 224, 225, 225, 225, 225, 226, 226, 226,
- 226, 226, 226, 227, 227, 227, 227, 228, 228, 228,
- 229, 229, 230, 230, 230, 231, 231, 232, 232, 232,
- 232, 232, 232, 232, 233, 233, 233, -1, -1, -1,
- -1, -1, -1, 234, 234, 234, 235, 235, 235, 235,
- 235, 235, 235, 235, 235, 235, 235, 236, 236, 237,
- 237, 238, 238, 239, 239, 239, 239, 240, 240, 241,
- 241, 242, 242, 243, 243, 243, 243, 243, 243, 243,
- 244, 244, 244, 244, 245, 245, 245, 245, 245, 245,
- 245, 245, 245, 245, 245, 245, 245, 245, 245, 246,
- 246, 246, 246, 246, 246, 246, 246, 246, 246, 246,
- 246, 246, 246, 246, 246, 246, 246, 246, 246, 246,
- 246, 246, 246, 246, 246, 246, 247, 248, 248, 249,
- 250
- };
- static const short yyr2[] = { 0,
- 3, 0, 3, 0, 2, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 6, 1, 6, 1, 6, 1,
- 6, 1, 6, 1, 6, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
- 1, 1, 1, 1, 1, 1, 1, 1, 1, 0,
- 2, 1, 1, 1, 7, 3, 8, 1, 1, 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, 3, 2, 2, 3, 1, 2,
- 3, 3, 3, 3, 1, 2, 2, 1, 2, 1,
- 2, 2, 2, 1, 2, 4, 3, 2, 2, 3,
- 5, 5, 1, 1, 1, 1, 1, 7, 2, 3,
- 3, 2, 2, 2, 2, 2, 2, 2, 2, 3,
- 3, 2, 3, 2, 3, 3, 3, 3, 3, 3,
- 3, 3, 3, 4, 4, 4, 4, 2, 2, 2,
- 0, 5, 2, 2, 2, 0, 5, 2, 4, 3,
- 2, 3, 3, 3, 2, 3, 3, 1, 1, 1,
- 1, 6, 7, 3, 2, 2, 1, 2, 1, 3,
- 2, 1, 2, 1, 1, 2, 3, 1, 2, 1,
- 2, 1, 2, 1, 2, 1, 2, 1, 2, 1,
- 2, 3, 3, 3, 3, 3, 3, 3, 3, 3,
- 2, 2, 2, 2, 3, 3, 3, 3, 3, 3,
- 2, 3, 3, 3, 2, 2, 1, 3, 3, 2,
- 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 3, 2, 2, 2, 2, 2, 2, 2, 2, 2,
- 2, 2, 2, 2, 2, 2, 2, 3, 8, 1,
- 5
- };
- static const short yydefact[] = { 0,
- 0, 14, 16, 18, 20, 22, 26, 0, 0, 0,
- 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, 83, 84,
- 85, 79, 80, 81, 82, 86, 87, 88, 89, 90,
- 91, 92, 93, 94, 95, 96, 97, 98, 99, 100,
- 101, 102, 103, 110, 111, 112, 113, 114, 115, 116,
- 104, 105, 106, 107, 108, 109, 117, 118, 119, 120,
- 121, 122, 123, 124, 125, 126, 127, 128, 129, 130,
- 131, 132, 133, 134, 135, 136, 137, 138, 139, 140,
- 141, 142, 143, 144, 145, 146, 147, 148, 149, 150,
- 151, 152, 153, 154, 155, 156, 157, 158, 159, 163,
- 164, 160, 165, 166, 167, 168, 169, 170, 161, 171,
- 162, 172, 173, 174, 175, 176, 177, 178, 179, 180,
- 181, 182, 183, 184, 185, 186, 187, 188, 189, 190,
- 191, 192, 193, 194, 195, 196, 197, 198, 199, 0,
- 6, 7, 8, 9, 10, 11, 24, 27, 28, 29,
- 30, 31, 32, 33, 34, 35, 36, 37, 39, 40,
- 38, 41, 42, 43, 44, 45, 46, 47, 48, 49,
- 50, 12, 13, 0, 232, 233, 0, 0, 200, 200,
- 0, 239, 0, 0, 0, 0, 245, 0, 0, 0,
- 254, 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, 301,
- 200, 200, 306, 200, 200, 200, 0, 0, 0, 0,
- 0, 327, 329, 0, 0, 332, 334, 335, 0, 344,
- 346, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 200, 377, 0, 0, 0, 0,
- 0, 0, 0, 200, 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, 208, 209, 210,
- 211, 212, 213, 214, 215, 216, 217, 218, 220, 221,
- 219, 222, 223, 224, 225, 226, 227, 228, 229, 230,
- 231, 200, 2, 0, 0, 410, 1, 2, 234, 0,
- 200, 236, 237, 0, 248, 240, 0, 0, 0, 0,
- 250, 246, 247, 252, 253, 255, 0, 0, 0, 0,
- 0, 202, 203, 258, 204, 259, 0, 269, 0, 0,
- 272, 273, 274, 279, 278, 277, 275, 276, 0, 0,
- 282, 0, 284, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 308, 0, 0, 311, 0, 0, 0,
- 0, 298, 299, 300, 0, 303, 304, 305, 315, 0,
- 0, 0, 325, 326, 338, 328, 0, 331, 340, 333,
- 342, 336, 0, 348, 345, 350, 347, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 361, 362, 363, 364,
- 376, 0, 0, 0, 0, 0, 0, 0, 371, 0,
- 375, 0, 0, 0, 380, 381, 382, 383, 384, 385,
- 386, 387, 388, 389, 390, 0, 392, 393, 394, 395,
- 396, 397, 398, 399, 400, 401, 402, 403, 404, 405,
- 406, 206, 407, 0, 0, 4, 408, 0, 235, 201,
- 238, 249, 241, 242, 243, 244, 251, 0, 0, 263,
- 0, 257, 2, 0, 0, 260, 270, 271, 280, 281,
- 283, 285, 286, 287, 288, 289, 290, 291, 292, 293,
- 0, 0, 0, 0, 0, 310, 312, 313, 314, 200,
- 200, 316, 317, 324, 339, 330, 341, 343, 337, 349,
- 351, 352, 353, 354, 355, 356, 357, 358, 359, 360,
- 365, 366, 378, 367, 368, 369, 370, 372, 373, 379,
- 374, 391, 0, 2, 0, 0, 4, 0, 256, 0,
- 0, 0, 0, 0, 294, 295, 296, 297, 309, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 3,
- 2, 0, 5, 0, 0, 0, 0, 4, 301, 306,
- 15, 17, 19, 21, 23, 0, 0, 25, 0, 411,
- 261, 262, 0, 0, 302, 307, 0, 0, 0, 0,
- 0, 207, 409, 205, 0, 268, 0, 0, 0
- };
- static const short yydefgoto[] = { 647,
- 504, 586, 361, 161, 162, 163, 164, 165, 166, 167,
- 168, 169, 170, 171, 172, 173, 174, 175, 176, 177,
- 178, 179, 180, 181, 182, 183, 184, 185, 186, 187,
- 188, 189, 190, 191, 362, 384, 192, 327, 328, 329,
- 366, 372, 330, 331, 332, 379, 521, 526, 333, 334,
- 335, 336, 337, 338, 339, 422, 340, 426, 341, 342,
- 343, 344, 436, 440, 442, 345, 445, 447, 346, 347,
- 348, 349, 350, 351, 193, 355, 356
- };
- static const short yypact[] = { -9,
- 617,-32768,-32768,-32768,-32768,-32768,-32768, 1441, 14, -30,
- -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,-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,-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,-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,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 5,
- -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,-32768, 17,-32768,-32768, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 20, 952, 952, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 952, 952, 952,
- 952, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 21,
- 617, 617, 23, 617, 617, 617, 617, 617, 617, 617,
- 617, 617,-32768, 617, 617, 617,-32768, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617,-32768, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, 617, 617, 617, 617, 24,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768, 617, 1282, 16, 19,-32768,-32768, 1282,-32768, 617,
- 617,-32768,-32768, 617, 617,-32768, 617, 617, 617, 617,
- 617,-32768,-32768,-32768,-32768,-32768, 617, -51, 952, 26,
- -18,-32768,-32768,-32768,-32768,-32768, 25,-32768, 617, 617,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768, 952, 617,
- -32768, 952,-32768, 617, 617, 617, 617, 617, 617, 617,
- 617, 617, -62,-32768, 617, 617,-32768, 617, 617, 617,
- -45,-32768,-32768,-32768, -46,-32768,-32768,-32768,-32768, 617,
- 617, 617,-32768,-32768, 617,-32768, 617,-32768, 617,-32768,
- 617,-32768, 617, 617,-32768, 617,-32768, 617, 617, 617,
- 617, 617, 617, 617, 617, 617,-32768,-32768,-32768,-32768,
- -32768, 617, 617, 617, 617, 617, 617, 617,-32768, 617,
- -32768, 617, 617, 617,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768, 617,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768, 30, 617, 18,-32768, 31,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768, 617, 617,-32768,
- 617,-32768, 1282, 27, -11,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- 952, 952, 952, 952, 617,-32768,-32768,-32768,-32768, 617,
- 617,-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, 786, 1282, 35, 29, 18, 33,-32768, 617,
- 617, 37, 18, 34,-32768,-32768,-32768,-32768,-32768, 40,
- 42, 39, 43, 47, 48, 49, 1441, -30, 51,-32768,
- 1282, 617,-32768, 44, 56, 1118, 50, 18, 21, 23,
- -32768,-32768,-32768,-32768,-32768, 57, 53,-32768, 58,-32768,
- -32768,-32768, 617, 54,-32768,-32768, 59, 60, 65, 66,
- 617,-32768,-32768,-32768, 67,-32768, 76, 77,-32768
- };
- static const short yypgoto[] = {-32768,
- -356, -581, -1,-32768,-32768,-32768, -50,-32768, -211, -239,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768, -195, -150, -207, -525,-32768,-32768,
- -280, -202,-32768,-32768,-32768,-32768,-32768,-32768,-32768,-32768,
- -32768,-32768,-32768,-32768,-32768, -533,-32768, -532,-32768,-32768,
- -32768,-32768, -348, -350, -349,-32768, -353, -352,-32768,-32768,
- -32768,-32768,-32768,-32768, -7, -515,-32768
- };
- #define YYLAST 1613
- static const short yytable[] = { 160,
- 352, 508, 383, 383, 363, 613, 385, 385, 376, 541,
- 542, 543, 1, 544, 519, 520, 383, 383, 383, 383,
- 385, 385, 385, 385, 5, 353, 354, 357, 358, 378,
- 421, 585, 425, 506, 502, 507, 634, 523, 524, 550,
- 525, 551, 583, 588, 593, 594, 611, 612, 608, 616,
- 619, 618, 620, 621, 631, 423, 424, 622, 427, 428,
- 429, 623, 624, 625, 386, 628, 632, 637, 633, 638,
- 639, 605, 641, 642, 643, 648, 649, 399, 400, 401,
- 402, 626, 644, 646, 512, 635, 555, 636, 557, 461,
- 560, 558, 627, 561, 0, 0, 0, 0, 469, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 505, 0, 0, 0, 0, 505, 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, 503, 0, 0, 0,
- 0, 0, 0, 382, 382, 510, 592, 383, 517, 0,
- 0, 385, 0, 0, 0, 0, 0, 382, 382, 382,
- 382, 0, 0, 0, 0, 0, 0, 383, 0, 0,
- 383, 385, 0, 0, 385, 359, 360, 0, 0, 364,
- 365, 367, 368, 369, 370, 371, 373, 374, 375, 371,
- 377, 0, 0, 0, 387, 388, 389, 390, 391, 392,
- 393, 394, 395, 396, 397, 398, 0, 610, 522, 0,
- 403, 404, 405, 406, 407, 408, 409, 410, 411, 412,
- 413, 414, 415, 416, 417, 418, 419, 420, 529, 0,
- 0, 531, 0, 0, 629, 430, 431, 432, 433, 434,
- 435, 0, 437, 438, 439, 0, 441, 443, 444, 446,
- 448, 449, 450, 451, 452, 453, 454, 455, 456, 457,
- 458, 459, 460, 505, 0, 462, 463, 464, 465, 466,
- 467, 468, 0, 470, 471, 472, 473, 474, 475, 476,
- 477, 478, 479, 480, 481, 482, 483, 484, 485, 486,
- 487, 488, 489, 490, 491, 492, 493, 494, 495, 496,
- 497, 498, 499, 500, 501, 0, 0, 0, 382, 383,
- 383, 383, 383, 385, 385, 385, 385, 0, 0, 0,
- 0, 0, 0, 609, 505, 0, 0, 0, 382, 0,
- 0, 382, 0, 0, 600, 601, 0, 0, 509, 0,
- 0, 0, 511, 365, 0, 513, 514, 515, 516, 371,
- 0, 505, 0, 0, 0, 518, 609, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 527, 528, 0,
- 595, 596, 597, 598, 0, 0, 0, 0, 530, 0,
- 0, 0, 532, 533, 534, 535, 536, 537, 538, 539,
- 540, 0, 0, 545, 546, 0, 547, 548, 549, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 552, 553,
- 554, 0, 0, 435, 0, 556, 0, 439, 0, 441,
- 0, 559, 444, 0, 446, 0, 562, 563, 564, 565,
- 566, 567, 568, 569, 570, 587, 0, 0, 0, 0,
- 571, 572, 573, 574, 575, 576, 577, 0, 578, 0,
- 579, 580, 581, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 582, 0, 0, 0, 0, 0,
- 382, 382, 382, 382, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 584, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 589, 590, 0, 591,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 587, 0, 0, 0,
- 0, 0, 617, 599, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 587, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 614, 615,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 352,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 630, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 2, 3, 4, 5, 6, 7, 8, 0, 0, 0,
- 9, 640, 10, 0, 0, 0, 0, 0, 0, 645,
- 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, 92, 93, 94, 95, 96, 97, 98, 99, 100,
- 101, 102, 103, 104, 105, 106, 107, 108, 109, 110,
- 111, 112, 113, 114, 115, 116, 117, 118, 119, 120,
- 121, 122, 123, 124, 125, 126, 127, 128, 129, 130,
- 131, 132, 133, 134, 135, 136, 137, 138, 139, 140,
- 141, 142, 143, 144, 145, 146, 147, 148, 149, 150,
- 151, 152, 153, 154, 155, 156, 157, 158, 159, 602,
- 603, 604, 605, 606, 7, 607, 0, 0, 0, 0,
- 0, 608, 0, 0, 0, 0, 0, 0, 0, 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,
- 92, 93, 94, 95, 96, 97, 98, 99, 100, 101,
- 102, 103, 104, 105, 106, 107, 108, 109, 110, 111,
- 112, 113, 114, 115, 116, 117, 118, 119, 120, 121,
- 122, 123, 124, 125, 126, 127, 128, 129, 130, 131,
- 132, 133, 134, 135, 136, 137, 138, 139, 140, 141,
- 142, 143, 144, 145, 146, 147, 148, 149, 150, 151,
- 152, 153, 154, 155, 156, 157, 158, 159, 5, 0,
- 7, 8, 0, 0, 0, 380, 0, 381, 0, 0,
- 0, 0, 0, 0, 0, 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, 92, 93, 94, 95,
- 96, 97, 98, 99, 100, 101, 102, 103, 104, 105,
- 106, 107, 108, 109, 110, 111, 112, 113, 114, 115,
- 116, 117, 118, 119, 120, 121, 122, 123, 124, 125,
- 126, 127, 128, 129, 130, 131, 132, 133, 134, 135,
- 136, 137, 138, 139, 140, 141, 142, 143, 144, 145,
- 146, 147, 148, 149, 150, 151, 152, 153, 154, 155,
- 156, 157, 158, 159, 605, 0, 7, 607, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 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, 92, 93, 94, 95, 96, 97, 98, 99,
- 100, 101, 102, 103, 104, 105, 106, 107, 108, 109,
- 110, 111, 112, 113, 114, 115, 116, 117, 118, 119,
- 120, 121, 122, 123, 124, 125, 126, 127, 128, 129,
- 130, 131, 132, 133, 134, 135, 136, 137, 138, 139,
- 140, 141, 142, 143, 144, 145, 146, 147, 148, 149,
- 150, 151, 152, 153, 154, 155, 156, 157, 158, 159,
- 7, 0, 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 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, 92, 93, 94, 95,
- 96, 97, 98, 99, 100, 101, 102, 103, 104, 105,
- 106, 107, 108, 109, 110, 111, 112, 113, 114, 115,
- 116, 117, 118, 119, 120, 121, 122, 123, 124, 125,
- 126, 127, 128, 129, 130, 131, 132, 133, 134, 135,
- 136, 137, 138, 139, 140, 141, 142, 143, 144, 145,
- 146, 147, 148, 149, 150, 151, 152, 153, 154, 155,
- 156, 157, 158, 159, 194, 0, 10, 0, 0, 0,
- 0, 0, 0, 0, 195, 196, 197, 198, 199, 200,
- 201, 202, 203, 204, 205, 206, 207, 208, 209, 210,
- 211, 212, 213, 214, 215, 216, 217, 218, 219, 220,
- 221, 222, 223, 224, 225, 226, 227, 0, 228, 229,
- 230, 231, 232, 233, 234, 235, 236, 237, 238, 239,
- 240, 241, 0, 0, 0, 242, 0, 243, 244, 245,
- 246, 247, 248, 249, 250, 251, 252, 253, 254, 255,
- 256, 257, 258, 259, 260, 261, 262, 263, 264, 265,
- 266, 267, 268, 269, 270, 271, 272, 0, 0, 0,
- 0, 0, 0, 273, 274, 275, 276, 277, 278, 279,
- 280, 281, 282, 283, 284, 0, 0, 0, 0, 0,
- 0, 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
- };
- static const short yycheck[] = { 1,
- 8, 358, 214, 215, 200, 587, 214, 215, 211, 72,
- 73, 74, 22, 76, 66, 67, 228, 229, 230, 231,
- 228, 229, 230, 231, 7, 12, 57, 23, 12, 10,
- 10, 14, 10, 18, 11, 17, 618, 12, 57, 85,
- 16, 88, 13, 13, 18, 57, 12, 19, 16, 13,
- 11, 18, 11, 15, 11, 251, 252, 15, 254, 255,
- 256, 15, 15, 15, 215, 15, 11, 11, 19, 17,
- 13, 7, 19, 15, 15, 0, 0, 228, 229, 230,
- 231, 607, 17, 17, 365, 619, 435, 620, 439, 285,
- 444, 441, 608, 446, -1, -1, -1, -1, 294, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, 353, -1, -1, -1, -1, 358, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, 352, -1, -1, -1,
- -1, -1, -1, 214, 215, 361, 523, 379, 371, -1,
- -1, 379, -1, -1, -1, -1, -1, 228, 229, 230,
- 231, -1, -1, -1, -1, -1, -1, 399, -1, -1,
- 402, 399, -1, -1, 402, 197, 198, -1, -1, 201,
- 202, 203, 204, 205, 206, 207, 208, 209, 210, 211,
- 212, -1, -1, -1, 216, 217, 218, 219, 220, 221,
- 222, 223, 224, 225, 226, 227, -1, 584, 379, -1,
- 232, 233, 234, 235, 236, 237, 238, 239, 240, 241,
- 242, 243, 244, 245, 246, 247, 248, 249, 399, -1,
- -1, 402, -1, -1, 611, 257, 258, 259, 260, 261,
- 262, -1, 264, 265, 266, -1, 268, 269, 270, 271,
- 272, 273, 274, 275, 276, 277, 278, 279, 280, 281,
- 282, 283, 284, 523, -1, 287, 288, 289, 290, 291,
- 292, 293, -1, 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, -1, -1, -1, 379, 541,
- 542, 543, 544, 541, 542, 543, 544, -1, -1, -1,
- -1, -1, -1, 583, 584, -1, -1, -1, 399, -1,
- -1, 402, -1, -1, 550, 551, -1, -1, 360, -1,
- -1, -1, 364, 365, -1, 367, 368, 369, 370, 371,
- -1, 611, -1, -1, -1, 377, 616, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, 389, 390, -1,
- 541, 542, 543, 544, -1, -1, -1, -1, 400, -1,
- -1, -1, 404, 405, 406, 407, 408, 409, 410, 411,
- 412, -1, -1, 415, 416, -1, 418, 419, 420, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, 430, 431,
- 432, -1, -1, 435, -1, 437, -1, 439, -1, 441,
- -1, 443, 444, -1, 446, -1, 448, 449, 450, 451,
- 452, 453, 454, 455, 456, 506, -1, -1, -1, -1,
- 462, 463, 464, 465, 466, 467, 468, -1, 470, -1,
- 472, 473, 474, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, 486, -1, -1, -1, -1, -1,
- 541, 542, 543, 544, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, 505, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, 518, 519, -1, 521,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, 587, -1, -1, -1,
- -1, -1, 593, 545, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, 618, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, 590, 591,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, 607,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- 612, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- 4, 5, 6, 7, 8, 9, 10, -1, -1, -1,
- 14, 633, 16, -1, -1, -1, -1, -1, -1, 641,
- 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, 92, 93,
- 94, 95, 96, 97, 98, 99, 100, 101, 102, 103,
- 104, 105, 106, 107, 108, 109, 110, 111, 112, 113,
- 114, 115, 116, 117, 118, 119, 120, 121, 122, 123,
- 124, 125, 126, 127, 128, 129, 130, 131, 132, 133,
- 134, 135, 136, 137, 138, 139, 140, 141, 142, 143,
- 144, 145, 146, 147, 148, 149, 150, 151, 152, 153,
- 154, 155, 156, 157, 158, 159, 160, 161, 162, 163,
- 164, 165, 166, 167, 168, 169, 170, 171, 172, 4,
- 5, 6, 7, 8, 9, 10, -1, -1, -1, -1,
- -1, 16, -1, -1, -1, -1, -1, -1, -1, 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, 92, 93, 94,
- 95, 96, 97, 98, 99, 100, 101, 102, 103, 104,
- 105, 106, 107, 108, 109, 110, 111, 112, 113, 114,
- 115, 116, 117, 118, 119, 120, 121, 122, 123, 124,
- 125, 126, 127, 128, 129, 130, 131, 132, 133, 134,
- 135, 136, 137, 138, 139, 140, 141, 142, 143, 144,
- 145, 146, 147, 148, 149, 150, 151, 152, 153, 154,
- 155, 156, 157, 158, 159, 160, 161, 162, 163, 164,
- 165, 166, 167, 168, 169, 170, 171, 172, 7, -1,
- 9, 10, -1, -1, -1, 14, -1, 16, -1, -1,
- -1, -1, -1, -1, -1, 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, 92, 93, 94, 95, 96, 97, 98,
- 99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
- 109, 110, 111, 112, 113, 114, 115, 116, 117, 118,
- 119, 120, 121, 122, 123, 124, 125, 126, 127, 128,
- 129, 130, 131, 132, 133, 134, 135, 136, 137, 138,
- 139, 140, 141, 142, 143, 144, 145, 146, 147, 148,
- 149, 150, 151, 152, 153, 154, 155, 156, 157, 158,
- 159, 160, 161, 162, 163, 164, 165, 166, 167, 168,
- 169, 170, 171, 172, 7, -1, 9, 10, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, 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, 92,
- 93, 94, 95, 96, 97, 98, 99, 100, 101, 102,
- 103, 104, 105, 106, 107, 108, 109, 110, 111, 112,
- 113, 114, 115, 116, 117, 118, 119, 120, 121, 122,
- 123, 124, 125, 126, 127, 128, 129, 130, 131, 132,
- 133, 134, 135, 136, 137, 138, 139, 140, 141, 142,
- 143, 144, 145, 146, 147, 148, 149, 150, 151, 152,
- 153, 154, 155, 156, 157, 158, 159, 160, 161, 162,
- 163, 164, 165, 166, 167, 168, 169, 170, 171, 172,
- 9, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, 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, 92, 93, 94, 95, 96, 97, 98,
- 99, 100, 101, 102, 103, 104, 105, 106, 107, 108,
- 109, 110, 111, 112, 113, 114, 115, 116, 117, 118,
- 119, 120, 121, 122, 123, 124, 125, 126, 127, 128,
- 129, 130, 131, 132, 133, 134, 135, 136, 137, 138,
- 139, 140, 141, 142, 143, 144, 145, 146, 147, 148,
- 149, 150, 151, 152, 153, 154, 155, 156, 157, 158,
- 159, 160, 161, 162, 163, 164, 165, 166, 167, 168,
- 169, 170, 171, 172, 14, -1, 16, -1, -1, -1,
- -1, -1, -1, -1, 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, -1, 58, 59,
- 60, 61, 62, 63, 64, 65, 66, 67, 68, 69,
- 70, 71, -1, -1, -1, 75, -1, 77, 78, 79,
- 80, 81, 82, 83, 84, 85, 86, 87, 88, 89,
- 90, 91, 92, 93, 94, 95, 96, 97, 98, 99,
- 100, 101, 102, 103, 104, 105, 106, -1, -1, -1,
- -1, -1, -1, 113, 114, 115, 116, 117, 118, 119,
- 120, 121, 122, 123, 124, -1, -1, -1, -1, -1,
- -1, 131, 132, 133, 134, 135, 136, 137, 138, 139,
- 140, 141, 142, 143, 144, 145, 146, 147, 148, 149,
- 150, 151, 152, 153, 154, 155, 156, 157, 158, 159,
- 160, 161, 162, 163, 164, 165, 166, 167, 168, 169,
- 170, 171, 172
- };
- /* -*-C-*- Note some compilers choke on comments on `#line' lines. */
- #line 3 "/usr/lib/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 <alloca.h>
- #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 <malloc.h>
- #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 <malloc.h> */
- #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 YYSTACK_ALLOC malloc
- #endif
- /* 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 YYEOF 0
- #define YYACCEPT goto yyacceptlab
- #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) \
- do \
- if (yychar == YYEMPTY && yylen == 1) \
- { yychar = (token), yylval = (value); \
- yychar1 = YYTRANSLATE (yychar); \
- YYPOPSTACK; \
- goto yybackup; \
- } \
- else \
- { yyerror ("syntax error: cannot back up"); YYERROR; } \
- while (0)
- #define YYTERROR 1
- #define YYERRCODE 256
- #ifndef YYPURE
- #define YYLEX yylex()
- #endif
- #ifdef YYPURE
- #ifdef YYLSP_NEEDED
- #ifdef YYLEX_PARAM
- #define YYLEX yylex(&yylval, &yylloc, YYLEX_PARAM)
- #else
- #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
- /* If nonreentrant, generate the variables here */
- #ifndef YYPURE
- int yychar; /* the lookahead symbol */
- YYSTYPE yylval; /* the semantic value of the */
- /* lookahead symbol */
- #ifdef YYLSP_NEEDED
- YYLTYPE yylloc; /* location data for the lookahead */
- /* symbol */
- #endif
- int yynerrs; /* number of parse errors so far */
- #endif /* not YYPURE */
- #if YYDEBUG != 0
- int yydebug; /* nonzero means print parse trace */
- /* Since this is uninitialized, it does not stop multiple parsers
- from coexisting. */
- #endif
- /* YYINITDEPTH indicates the initial size of the parser's stacks */
- #ifndef YYINITDEPTH
- #define YYINITDEPTH 200
- #endif
- /* YYMAXDEPTH is the maximum size the stacks can grow to
- (effective only if the built-in stack extension method is used). */
- #if YYMAXDEPTH == 0
- #undef YYMAXDEPTH
- #endif
- #ifndef YYMAXDEPTH
- #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 __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
- /* This is the most reliable way to avoid incompatibilities
- in available built-in functions on various systems. */
- static void
- __yy_memcpy (to, from, count)
- char *to;
- char *from;
- unsigned int count;
- {
- register char *f = from;
- register char *t = to;
- register int i = count;
- while (i-- > 0)
- *t++ = *f++;
- }
- #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/lib/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
- #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 (void);
- #endif
- #endif
- int
- yyparse(YYPARSE_PARAM_ARG)
- YYPARSE_PARAM_DECL
- {
- 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
- int yystacksize = YYINITDEPTH;
- int yyfree_stacks = 0;
- #ifdef YYPURE
- int yychar;
- YYSTYPE yylval;
- int yynerrs;
- #ifdef YYLSP_NEEDED
- YYLTYPE yylloc;
- #endif
- #endif
- YYSTYPE yyval; /* the variable used to return */
- /* semantic values from the action */
- /* routines */
- int yylen;
- #if YYDEBUG != 0
- if (yydebug)
- fprintf(stderr, "Starting parse\n");
- #endif
- yystate = 0;
- yyerrstatus = 0;
- yynerrs = 0;
- yychar = YYEMPTY; /* Cause a token to be read. */
- /* Initialize stack pointers.
- Waste one element of value and location stack
- so that they stay on the same level as the state stack.
- The wasted elements are never initialized. */
- yyssp = yyss - 1;
- yyvsp = yyvs;
- #ifdef YYLSP_NEEDED
- yylsp = yyls;
- #endif
- /* 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:
- *++yyssp = yystate;
- 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. */
- int size = yyssp - yyss + 1;
- #ifdef yyoverflow
- /* 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
- yyss = yyss1; yyvs = yyvs1;
- #ifdef YYLSP_NEEDED
- yyls = yyls1;
- #endif
- #else /* no yyoverflow */
- /* Extend the stack our own way. */
- 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 (yystacksize > YYMAXDEPTH)
- yystacksize = YYMAXDEPTH;
- #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 + 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
- if (yyssp >= yyss + yystacksize - 1)
- YYABORT;
- }
- #if YYDEBUG != 0
- if (yydebug)
- fprintf(stderr, "Entering state %d\n", yystate);
- #endif
- goto yybackup;
- yybackup:
- /* Do appropriate processing given the current state. */
- /* Read a lookahead token if we need one and don't already have one. */
- /* yyresume: */
- /* First try to decide what to do without reference to lookahead token. */
- yyn = yypact[yystate];
- if (yyn == YYFLAG)
- goto yydefault;
- /* 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. */
- if (yychar == YYEMPTY)
- {
- #if YYDEBUG != 0
- if (yydebug)
- fprintf(stderr, "Reading a token: ");
- #endif
- yychar = YYLEX;
- }
- /* Convert token to internal form (in yychar1) for indexing tables with */
- if (yychar <= 0) /* This means end of input. */
- {
- 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
- {
- 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
- }
- yyn += yychar1;
- if (yyn < 0 || yyn > YYLAST || yycheck[yyn] != yychar1)
- goto yydefault;
- yyn = yytable[yyn];
- /* 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 == YYFLAG)
- goto yyerrlab;
- yyn = -yyn;
- goto yyreduce;
- }
- else if (yyn == 0)
- goto yyerrlab;
- if (yyn == YYFINAL)
- YYACCEPT;
- /* Shift the lookahead token. */
- #if YYDEBUG != 0
- if (yydebug)
- fprintf(stderr, "Shifting token %d (%s), ", yychar, yytname[yychar1]);
- #endif
- /* Discard the token being shifted unless it is eof. */
- if (yychar != YYEOF)
- yychar = YYEMPTY;
- *++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;
- /* Do the default action for the current state. */
- yydefault:
- yyn = yydefact[yystate];
- if (yyn == 0)
- goto yyerrlab;
- /* Do a reduction. yyn is the number of a rule to reduce with. */
- yyreduce:
- yylen = yyr2[yyn];
- if (yylen > 0)
- yyval = yyvsp[1-yylen]; /* implement default value of the action */
- #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 1:
- #line 298 "omparser.y"
- { yyval = yyvsp[-1]; inObj = yyvsp[-1]; YYACCEPT; ;
- break;}
- case 3:
- #line 304 "omparser.y"
- { /* TODO */ ;
- break;}
- case 4:
- #line 309 "omparser.y"
- { yyval = C_nil; ;
- break;}
- case 5:
- #line 311 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 14:
- #line 328 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 15:
- #line 330 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 16:
- #line 335 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 17:
- #line 337 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 18:
- #line 342 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 19:
- #line 344 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 20:
- #line 349 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 21:
- #line 351 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 22:
- #line 356 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 23:
- #line 358 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 24:
- #line 363 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 25:
- #line 365 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 200:
- #line 620 "omparser.y"
- { yyval = C_nil; ;
- break;}
- case 201:
- #line 622 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 202:
- #line 630 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0],var);
- yyval = list2(list2(yyvsp[0], var), var);
- pop2(var,yyvsp[0]);
- ;
- break;}
- case 203:
- #line 638 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0],var);
- yyval = list2(list2(yyvsp[0], var), var);
- pop2(var,yyvsp[0]);
- ;
- break;}
- case 204:
- #line 646 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0],var);
- yyval = list2(list2(yyvsp[0], var), var);
- pop2(var,yyvsp[0]);
- ;
- break;}
- case 205:
- #line 653 "omparser.y"
- { push2(yyvsp[-1], yyvsp[-3]);
- yyval = list2(yyvsp[-1], yyvsp[-3]);
- pop2(yyvsp[-3], yyvsp[-1]);
- ;
- break;}
- case 206:
- #line 661 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 207:
- #line 663 "omparser.y"
- { yyval = yyvsp[-2]; ;
- break;}
- case 232:
- #line 695 "omparser.y"
- { yyval = fixnum_of_int(0); ;
- break;}
- case 233:
- #line 697 "omparser.y"
- { yyval = fixnum_of_int(1); ;
- break;}
- case 234:
- #line 702 "omparser.y"
- { push2(yyvsp[-1],yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 235:
- #line 707 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 236:
- #line 712 "omparser.y"
- { push2(yyvsp[-1],yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 237:
- #line 717 "omparser.y"
- { push2(yyvsp[-1],yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 238:
- #line 722 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 239:
- #line 727 "omparser.y"
- { yyval = fixnum_of_int(0); ;
- break;}
- case 240:
- #line 729 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 241:
- #line 731 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 242:
- #line 736 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 243:
- #line 741 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 244:
- #line 746 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 245:
- #line 751 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 246:
- #line 753 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 247:
- #line 755 "omparser.y"
- { push2(yyvsp[-1],yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 248:
- #line 763 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 249:
- #line 765 "omparser.y"
- { Lisp_Object obj = StrToLspM("+");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 250:
- #line 774 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 251:
- #line 776 "omparser.y"
- { Lisp_Object obj = StrToLspM("*");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 252:
- #line 785 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 253:
- #line 790 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 254:
- #line 795 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 255:
- #line 799 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 256:
- #line 804 "omparser.y"
- { push4(yyvsp[-3], yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = cons(yyvsp[-3], list3(yyvsp[-2], yyvsp[0], yyvsp[-1]));
- pop4(yyvsp[0], yyvsp[-1], yyvsp[-2], yyvsp[-3]);
- ;
- break;}
- case 257:
- #line 812 "omparser.y"
- {/* (|integrate| function range) */
- /* FIXME: needs to treat more general cases as well... */
- push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(
- yyvsp[-2],
- qcar(yyvsp[0]),
- list3(
- StrToLspM("="),
- qcar(qcdr(yyvsp[0])),
- yyvsp[-1]
- )
- );
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 258:
- #line 827 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 259:
- #line 829 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = yyvsp[0];
- yyval = cons(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 260:
- #line 835 "omparser.y"
- {/* (|differentiate| function (|construct| vars...)) */
- Lisp_Object varIndList, varList;
- Lisp_Object funcObj, quoteObj;
- push(yyvsp[-1]);
- varIndList = Ceval(yyvsp[-1], C_nil);
- pop(yyvsp[-1]);
- push(yyvsp[0]);
- varList = qcar(yyvsp[0]);
- funcObj = qcar(qcdr(yyvsp[0]));
- pop(yyvsp[0]);
- /* Get names corresponding to variable indices.
- */
- quoteObj = StrToLspM("QUOTE");
- push3(quoteObj, varList, varIndList);
- varList = list3(
- StrToLspM("MAPCAR"),
- list2(
- quoteObj,
- list3(
- StrToLspM("LAMBDA"),
- cons(MkUndefSymM("i"), C_nil),
- list3(
- StrToLspM("NTH"),
- list3(
- StrToLspM("-"),
- MkUndefSymM("i"),
- fixnum_of_int(1)),
- list2(quoteObj, varList)))),
- list2(quoteObj, varIndList));
- pop3(varIndList, varList, quoteObj);
- push(varList);
- varList = Ceval(varList, C_nil);
- varList = cons(
- StrToLspM("construct"),
- varList);
- pop(varList);
- push3(yyvsp[-2], funcObj, varList);
- yyval = list3(yyvsp[-2], funcObj, varList);
- pop3(varList, funcObj, yyvsp[-2]);
- ;
- break;}
- case 261:
- #line 884 "omparser.y"
- { /* (|segment| lo hi) */
- push3(yyvsp[-3], yyvsp[-2], yyvsp[-1]);
- yyval = list3(yyvsp[-3], yyvsp[-2], yyvsp[-1]);
- pop3(yyvsp[-1], yyvsp[-2], yyvsp[-3]);
- ;
- break;}
- case 262:
- #line 890 "omparser.y"
- { Lisp_Object segObj = StrToLspM("segment");
- Lisp_Object coerceObj = StrToLspM("::");
- Lisp_Object typeObj = list2(StrToLspM("Fraction"), StrToLspM("Integer"));
- push3(segObj, coerceObj, typeObj);
- yyval = list3(
- segObj,
- list3(coerceObj, yyvsp[-2], typeObj),
- list3(coerceObj, yyvsp[-1], typeObj)
- );
- pop3(typeObj, coerceObj, segObj);
- ;
- break;}
- case 268:
- #line 915 "omparser.y"
- { push2(yyvsp[-3], yyvsp[-1]);
- yyval = list2(yyvsp[-3], yyvsp[-1]);
- pop2(yyvsp[-1], yyvsp[-3]);
- ;
- break;}
- case 269:
- #line 923 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 270:
- #line 928 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 271:
- #line 933 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- /* Unhandled Symbol */
- yyval = list3(yyvsp[-2], make_string("complex_polar"), make_string("complex1"));
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 272:
- #line 939 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 273:
- #line 944 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 274:
- #line 949 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 275:
- #line 959 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 276:
- #line 961 "omparser.y"
- { yyval = list3(yyvsp[-1], make_string("inverse"), make_string("fns1")); ;
- break;}
- case 277:
- #line 963 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-1], make_string("image"), make_string("fns1"));
- pop2(yyvsp[-1], yyvsp[0]);
- ;
- break;}
- case 278:
- #line 968 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-1], make_string("range"), make_string("fns1"));
- pop2(yyvsp[-1], yyvsp[0]);
- ;
- break;}
- case 279:
- #line 973 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-1], make_string("domain"), make_string("fns1"));
- pop2(yyvsp[-1], yyvsp[0]);
- ;
- break;}
- case 280:
- #line 978 "omparser.y"
- {/* (ADEF (bv2) (NIL NIL) (NIL NIL) (func1 (func2 bv2))) */
- Lisp_Object types, bv1, bv2, func1, func2;
- types = list2(C_nil, C_nil);
- func1 = qcar(yyvsp[-1]);
- bv1 = qcar(qcdr(yyvsp[-1]));
- func2 = qcar(yyvsp[0]);
- bv2 = qcar(qcdr(yyvsp[0]));
- push3(func1, func2, bv1);
- func1 = Ceval(
- cons(
- StrToLspM("SUBST"),
- list3(
- list2(StrToLspM("QUOTE"), func2),
- list2(StrToLspM("QUOTE"), bv1),
- list2(StrToLspM("QUOTE"), func1)
- )
- ),
- C_nil
- );
- pop3(bv1, func2, func1);
- push4(yyvsp[-2], bv2, types, func1);
- yyval = cons(yyvsp[-2], cons(cons(bv2, C_nil), list3(types, types, func1)));
- pop4(func1, types, bv2, yyvsp[-2]);
- ;
- break;}
- case 281:
- #line 1008 "omparser.y"
- { push3(yyvsp[-2],yyvsp[-1],yyvsp[0]);
- yyval = list3(yyvsp[-2],yyvsp[-1],yyvsp[0]);
- pop3(yyvsp[0],yyvsp[-1],yyvsp[-2]);
- ;
- break;}
- case 282:
- #line 1013 "omparser.y"
- {yyval = list3(yyvsp[-1], make_string("kernel"), make_string("fns2")); ;
- break;}
- case 283:
- #line 1015 "omparser.y"
- {/* (ADEF (bv1) (NIL NIL) (NIL NIL) (func2 (func1 bv1))) */
- Lisp_Object types, bv1, bv2, func1, func2;
- types = list2(C_nil, C_nil);
- func1 = qcar(yyvsp[-1]);
- bv1 = qcar(qcdr(yyvsp[-1]));
- func2 = qcar(yyvsp[0]);
- bv2 = qcar(qcdr(yyvsp[0]));
- push3(func1, func2, bv2);
- func1 = Ceval(
- cons(
- StrToLspM("SUBST"),
- list3(
- list2(StrToLspM("QUOTE"), func1),
- list2(StrToLspM("QUOTE"), bv2),
- list2(StrToLspM("QUOTE"), func2)
- )
- ),
- C_nil
- );
- pop3(bv2, func2, func1);
- push4(yyvsp[-2], bv2, types, func2);
- yyval = cons(yyvsp[-2], cons(cons(bv1, C_nil), list3(types, types, func2)));
- pop4(func2, types, bv2, yyvsp[-2]);
- ;
- break;}
- case 284:
- #line 1045 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 285:
- #line 1050 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], make_string("factorof"), make_string("integer1"));
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 286:
- #line 1055 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 287:
- #line 1060 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 288:
- #line 1068 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 289:
- #line 1073 "omparser.y"
- { Lisp_Object interpObj = StrToLspM("@");
- Lisp_Object typeObj = list2(
- StrToLspM("Interval"),
- StrToLspM("DoubleFloat")
- );
- push5(yyvsp[-2], yyvsp[-1], yyvsp[0], interpObj, typeObj);
- yyval = list3(interpObj, list3(yyvsp[-2], yyvsp[-1], yyvsp[0]), typeObj);
- pop5(typeObj, interpObj, yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 290:
- #line 1083 "omparser.y"
- { Lisp_Object interpObj = StrToLspM("@");
- Lisp_Object typeObj = list2(
- StrToLspM("Interval"),
- StrToLspM("DoubleFloat")
- );
- push5(yyvsp[-2], yyvsp[-1], yyvsp[0], interpObj, typeObj);
- yyval = list3(interpObj, list3(yyvsp[-2], yyvsp[-1], yyvsp[0]), typeObj);
- pop5(typeObj, interpObj, yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 291:
- #line 1093 "omparser.y"
- { Lisp_Object interpObj = StrToLspM("@");
- Lisp_Object typeObj = list2(
- StrToLspM("Interval"),
- StrToLspM("DoubleFloat")
- );
- double dLo = float_of_number(yyvsp[-1]);
- double dHi = float_of_number(yyvsp[0]);
- if (dLo > dHi) {
- double dt = dLo;
- dLo = dHi;
- dHi = dt;
- }
- dHi -= DBL_EPSILON;
- push3(yyvsp[-2], interpObj, typeObj);
- yyval = list3(interpObj, list3(yyvsp[-2],
- make_boxfloat(dLo, TYPE_DOUBLE_FLOAT),
- make_boxfloat(dHi, TYPE_DOUBLE_FLOAT)
- ), typeObj);
- pop3(typeObj, interpObj, yyvsp[-2]);
- ;
- break;}
- case 292:
- #line 1114 "omparser.y"
- { Lisp_Object interpObj = StrToLspM("@");
- Lisp_Object typeObj = list2(
- StrToLspM("Interval"),
- StrToLspM("DoubleFloat")
- );
- double dLo = float_of_number(yyvsp[-1]);
- double dHi = float_of_number(yyvsp[0]);
- if (dLo > dHi) {
- double dt = dLo;
- dLo = dHi;
- dHi = dt;
- }
- dLo += DBL_EPSILON;
- push3(yyvsp[-2], interpObj, typeObj);
- yyval = list3(interpObj, list3(yyvsp[-2],
- make_boxfloat(dLo, TYPE_DOUBLE_FLOAT),
- make_boxfloat(dHi, TYPE_DOUBLE_FLOAT)
- ), typeObj);
- pop3(typeObj, interpObj, yyvsp[-2]);
- ;
- break;}
- case 293:
- #line 1135 "omparser.y"
- { Lisp_Object interpObj = StrToLspM("@");
- Lisp_Object typeObj = list2(
- StrToLspM("Interval"),
- StrToLspM("DoubleFloat")
- );
- double dLo = float_of_number(yyvsp[-1]);
- double dHi = float_of_number(yyvsp[0]);
- if (dLo > dHi) {
- double dt = dLo;
- dLo = dHi;
- dHi = dt;
- }
- dLo += DBL_EPSILON;
- dHi -= DBL_EPSILON;
- push3(yyvsp[-2], interpObj, typeObj);
- yyval = list3(interpObj, list3(yyvsp[-2],
- make_boxfloat(dLo, TYPE_DOUBLE_FLOAT),
- make_boxfloat(dHi, TYPE_DOUBLE_FLOAT)
- ), typeObj);
- pop3(typeObj, interpObj, yyvsp[-2]);
- ;
- break;}
- case 294:
- #line 1160 "omparser.y"
- {/* (|limit| func (|=| var limiting_val) "right") */
- Lisp_Object limitVal;
- push2(yyvsp[0], yyvsp[-2]);
- limitVal = list3(
- StrToLspM("="),
- qcar(qcdr(yyvsp[0])),
- list3(
- StrToLspM("::"),
- yyvsp[-2],
- list2(
- StrToLspM("Fraction"),
- StrToLspM("Integer")
- )
- )
- );
- pop2(yyvsp[-2], yyvsp[0]);
- push2(yyvsp[-3], yyvsp[0]);
- yyval = cons(yyvsp[-3], list3(qcar(yyvsp[0]), limitVal, make_string("right")));
- pop2(yyvsp[0], yyvsp[-3]);
- ;
- break;}
- case 295:
- #line 1181 "omparser.y"
- {/* (|limit| func (|=| var limiting_val) "left") */
- Lisp_Object limitVal;
- push2(yyvsp[0], yyvsp[-2]);
- limitVal = list3(
- StrToLspM("="),
- qcar(qcdr(yyvsp[0])),
- list3(
- StrToLspM("::"),
- yyvsp[-2],
- list2(
- StrToLspM("Fraction"),
- StrToLspM("Integer")
- )
- )
- );
- pop2(yyvsp[-2], yyvsp[0]);
- push2(yyvsp[-3], yyvsp[0]);
- yyval = cons(yyvsp[-3], list3(qcar(yyvsp[0]), limitVal, make_string("left")));
- pop2(yyvsp[0], yyvsp[-3]);
- ;
- break;}
- case 296:
- #line 1202 "omparser.y"
- {/* (|limit| func (|=| var limiting_val)) */
- Lisp_Object limitVal;
- push2(yyvsp[0], yyvsp[-2]);
- limitVal = list3(
- StrToLspM("="),
- qcar(qcdr(yyvsp[0])),
- list3(
- StrToLspM("::"),
- yyvsp[-2],
- list2(
- StrToLspM("Fraction"),
- StrToLspM("Integer")
- )
- )
- );
- pop2(yyvsp[-2], yyvsp[0]);
- push2(yyvsp[-3], yyvsp[0]);
- yyval = list3(yyvsp[-3], qcar(yyvsp[0]), limitVal);
- pop2(yyvsp[0], yyvsp[-3]);
- ;
- break;}
- case 297:
- #line 1223 "omparser.y"
- {/* (|limit| func (|=| var limiting_val)) */
- Lisp_Object limitVal;
- push2(yyvsp[0], yyvsp[-2]);
- limitVal = list3(
- StrToLspM("="),
- qcar(qcdr(yyvsp[0])),
- list3(
- StrToLspM("::"),
- yyvsp[-2],
- list2(
- StrToLspM("Fraction"),
- StrToLspM("Integer")
- )
- )
- );
- pop2(yyvsp[-2], yyvsp[0]);
- push2(yyvsp[-3], yyvsp[0]);
- yyval = list3(yyvsp[-3], qcar(yyvsp[0]), limitVal);
- pop2(yyvsp[0], yyvsp[-3]);
- ;
- break;}
- case 298:
- #line 1247 "omparser.y"
- { Lisp_Object obj = StrToLspM("construct");
- push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], cons(obj, yyvsp[0]));
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 299:
- #line 1253 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 300:
- #line 1255 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 301:
- #line 1260 "omparser.y"
- { yyval = C_nil; ;
- break;}
- case 302:
- #line 1262 "omparser.y"
- { yyval = cons(cons(yyvsp[-3], yyvsp[-2]), yyvsp[0]); ;
- break;}
- case 303:
- #line 1267 "omparser.y"
- { Lisp_Object cns = StrToLspM("construct");
- Lisp_Object trn = StrToLspM("transpose");
- push4(trn, yyvsp[-1], cns, yyvsp[0]);
- yyval = list2(trn, list2(yyvsp[-1], cons(cns, yyvsp[0])));
- pop4(yyvsp[0], cns, yyvsp[-1], trn);
- ;
- break;}
- case 304:
- #line 1274 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 305:
- #line 1276 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 306:
- #line 1281 "omparser.y"
- { yyval = C_nil; ;
- break;}
- case 307:
- #line 1283 "omparser.y"
- { yyval = cons( cons(yyvsp[-3], yyvsp[-2]), yyvsp[0] ); ;
- break;}
- case 308:
- #line 1288 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 309:
- #line 1293 "omparser.y"
- { yyval = cons(yyvsp[-3], list3(yyvsp[-1], yyvsp[0], yyvsp[-2])); ;
- break;}
- case 310:
- #line 1295 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[0], yyvsp[-1]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 311:
- #line 1300 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 312:
- #line 1305 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 313:
- #line 1310 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 314:
- #line 1315 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 315:
- #line 1323 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 316:
- #line 1325 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 317:
- #line 1330 "omparser.y"
- { /* Deliberately swap arguments for AXIOM */
- push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[0], yyvsp[-1]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 318:
- #line 1344 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0], var);
- yyval = list2(var, list2(yyvsp[0], var));
- pop2(var, yyvsp[0]);
- ;
- break;}
- case 319:
- #line 1352 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0], var);
- yyval = list2(var, list2(yyvsp[0], var));
- pop2(var, yyvsp[0]);
- ;
- break;}
- case 320:
- #line 1360 "omparser.y"
- { Lisp_Object var = MkUndefSymM("x");
- push2(yyvsp[0], var);
- yyval = list2(var, list2(yyvsp[0], var));
- pop2(var, yyvsp[0]);
- ;
- break;}
- case 321:
- #line 1366 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 322:
- #line 1368 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 323:
- #line 1374 "omparser.y"
- { push2(yyvsp[-3], yyvsp[-1]);
- yyval = list2(yyvsp[-3], yyvsp[-1]);
- pop2(yyvsp[-1], yyvsp[-3]);
- ;
- break;}
- case 324:
- #line 1382 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 325:
- #line 1387 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 326:
- #line 1392 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 327:
- #line 1400 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 328:
- #line 1402 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 329:
- #line 1404 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 330:
- #line 1406 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 331:
- #line 1411 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 332:
- #line 1416 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 333:
- #line 1418 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 334:
- #line 1420 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 335:
- #line 1422 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 336:
- #line 1424 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 337:
- #line 1426 "omparser.y"
- {yyval = list3(yyvsp[-2], make_string("equivalent"), make_string("logic1")); ;
- break;}
- case 338:
- #line 1431 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 339:
- #line 1433 "omparser.y"
- { Lisp_Object obj = StrToLspM("and");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 340:
- #line 1442 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 341:
- #line 1444 "omparser.y"
- { Lisp_Object obj = StrToLspM("or");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 342:
- #line 1453 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 343:
- #line 1455 "omparser.y"
- { Lisp_Object obj = StrToLspM("xor");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 344:
- #line 1464 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 345:
- #line 1466 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 346:
- #line 1468 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 347:
- #line 1470 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 348:
- #line 1475 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 349:
- #line 1477 "omparser.y"
- { Lisp_Object obj = StrToLspM("max");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 350:
- #line 1486 "omparser.y"
- { yyval = yyvsp[0]; ;
- break;}
- case 351:
- #line 1488 "omparser.y"
- { Lisp_Object obj = StrToLspM("min");
- push3(obj, yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], obj);
- ;
- break;}
- case 352:
- #line 1499 "omparser.y"
- {yyval = list3(yyvsp[-2], make_string("based_integer"), make_string("nums1")); ;
- break;}
- case 353:
- #line 1501 "omparser.y"
- {/* (|@| (/ numer denom) (|Fraction| |Integer|)) */
- push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(
- StrToLspM("@"),
- list3(yyvsp[-2], yyvsp[-1], yyvsp[0]),
- list2(
- StrToLspM("Fraction"),
- StrToLspM("Integer")
- )
- );
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 354:
- #line 1517 "omparser.y"
- { Lisp_Object coerceObj = StrToLspM("::");
- Lisp_Object nameObj = StrToLspM("SExpression");
- push5(yyvsp[-2], yyvsp[-1], yyvsp[0], coerceObj, nameObj);
- yyval = list3(yyvsp[-2],
- list3(coerceObj, yyvsp[-1], nameObj),
- list3(coerceObj, yyvsp[0], nameObj)
- );
- pop5(nameObj, coerceObj, yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 355:
- #line 1527 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 356:
- #line 1532 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 357:
- #line 1537 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 358:
- #line 1542 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 359:
- #line 1547 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 360:
- #line 1552 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], make_string("approx"), make_string("relation1"));
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 361:
- #line 1560 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 362:
- #line 1565 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 363:
- #line 1570 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 364:
- #line 1575 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 365:
- #line 1583 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 366:
- #line 1588 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 367:
- #line 1593 "omparser.y"
- { Lisp_Object notObj = StrToLspM("not");
- push4(notObj, yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list2(notObj, list3(yyvsp[-2], yyvsp[-1], yyvsp[0]));
- pop4(yyvsp[0], yyvsp[-1], yyvsp[-2], notObj);
- ;
- break;}
- case 368:
- #line 1599 "omparser.y"
- { Lisp_Object notObj = StrToLspM("not");
- push4(notObj, yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list2(notObj, list3(yyvsp[-2], yyvsp[-1], yyvsp[0]));
- pop4(yyvsp[0], yyvsp[-1], yyvsp[-2], notObj);
- ;
- break;}
- case 369:
- #line 1605 "omparser.y"
- { Lisp_Object notObj = StrToLspM("not");
- push4(notObj, yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list2(notObj, list3(yyvsp[-2], yyvsp[-1], yyvsp[0]));
- pop4(yyvsp[0], yyvsp[-1], yyvsp[-2], notObj);
- ;
- break;}
- case 370:
- #line 1611 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 371:
- #line 1616 "omparser.y"
- {
- yyval = cons(yyvsp[-1], yyvsp[0]);
- ;
- break;}
- case 372:
- #line 1620 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 373:
- #line 1625 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 374:
- #line 1630 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 375:
- #line 1635 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 376:
- #line 1640 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-1], make_string("cartesian_product"), make_string("set1"));
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 377:
- #line 1645 "omparser.y"
- { push(yyvsp[0]);
- yyval = Llist(C_nil, yyvsp[0]);
- pop(yyvsp[0]);
- ;
- break;}
- case 378:
- #line 1650 "omparser.y"
- { push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 379:
- #line 1655 "omparser.y"
- { /* Deliberately swap arguments for AXIOM */
- push3(yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(yyvsp[-2], yyvsp[0], yyvsp[-1]);
- pop3(yyvsp[0], yyvsp[-1], yyvsp[-2]);
- ;
- break;}
- case 380:
- #line 1664 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 381:
- #line 1669 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 382:
- #line 1674 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 383:
- #line 1679 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 384:
- #line 1684 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 385:
- #line 1689 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 386:
- #line 1694 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 387:
- #line 1699 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 388:
- #line 1704 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 389:
- #line 1709 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 390:
- #line 1714 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 391:
- #line 1719 "omparser.y"
- { Lisp_Object obj = StrToLspM("/");
- push4(obj, yyvsp[-2], yyvsp[-1], yyvsp[0]);
- yyval = list3(obj, list2(yyvsp[-2], yyvsp[0]), list2(yyvsp[-2], yyvsp[-1]));
- pop4(yyvsp[0], yyvsp[-1], yyvsp[-2], obj);
- ;
- break;}
- case 392:
- #line 1725 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 393:
- #line 1730 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 394:
- #line 1735 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 395:
- #line 1740 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 396:
- #line 1745 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 397:
- #line 1750 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 398:
- #line 1755 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 399:
- #line 1760 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 400:
- #line 1765 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 401:
- #line 1770 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 402:
- #line 1775 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 403:
- #line 1780 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 404:
- #line 1785 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 405:
- #line 1790 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 406:
- #line 1795 "omparser.y"
- { push2(yyvsp[-1], yyvsp[0]);
- yyval = list2(yyvsp[-1], yyvsp[0]);
- pop2(yyvsp[0], yyvsp[-1]);
- ;
- break;}
- case 407:
- #line 1803 "omparser.y"
- { yyval = cons(yyvsp[-1], yyvsp[0]); ;
- break;}
- case 408:
- #line 1808 "omparser.y"
- { yyval = yyvsp[-1]; ;
- break;}
- case 409:
- #line 1810 "omparser.y"
- { yyval = yyvsp[-2]; ;
- break;}
- case 411:
- #line 1819 "omparser.y"
- { Lisp_Object types = C_nil;
- Lisp_Object llen = Llength(C_nil, yyvsp[-2]);
- int len = int_of_fixnum(llen);
- int i;
- for (i = 0; i < len; i++)
- types = cons(C_nil, types);
- types = cons(C_nil, types);
- push4(yyvsp[-4], yyvsp[-2], yyvsp[0], types);
- yyval = cons(yyvsp[-4], cons(yyvsp[-2], list3(types, types, yyvsp[0])));
- pop4(types, yyvsp[0], yyvsp[-2], yyvsp[-4]);
- ;
- break;}
- }
- /* the action file gets copied in in place of this dollarsign */
- #line 543 "/usr/lib/bison.simple"
- yyvsp -= yylen;
- yyssp -= yylen;
- #ifdef YYLSP_NEEDED
- yylsp -= yylen;
- #endif
- #if YYDEBUG != 0
- if (yydebug)
- {
- short *ssp1 = yyss - 1;
- fprintf (stderr, "state stack now");
- while (ssp1 != yyssp)
- fprintf (stderr, " %d", *++ssp1);
- fprintf (stderr, "\n");
- }
- #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. */
- yyn = yyr1[yyn];
- yystate = yypgoto[yyn - YYNTBASE] + *yyssp;
- if (yystate >= 0 && yystate <= YYLAST && yycheck[yystate] == *yyssp)
- yystate = yytable[yystate];
- else
- yystate = yydefgoto[yyn - YYNTBASE];
- goto yynewstate;
- yyerrlab: /* here on detecting error */
- if (! yyerrstatus)
- /* If not already recovering from an error, report this error. */
- {
- ++yynerrs;
- #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 lookahead token after an error, discard it. */
- /* 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
- 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;
- #ifdef YYLSP_NEEDED
- *++yylsp = yylloc;
- #endif
- yystate = yyn;
- goto yynewstate;
- yyacceptlab:
- /* YYACCEPT comes here. */
- if (yyfree_stacks)
- {
- free (yyss);
- free (yyvs);
- #ifdef YYLSP_NEEDED
- free (yyls);
- #endif
- }
- return 0;
- yyabortlab:
- /* YYABORT comes here. */
- if (yyfree_stacks)
- {
- free (yyss);
- free (yyvs);
- #ifdef YYLSP_NEEDED
- free (yyls);
- #endif
- }
- return 1;
- }
- #line 1834 "omparser.y"
- /* C code. */
- typedef struct {
- char *cd;
- char *name;
- char *axname;
- YYSTYPE token;
- } symTableItem;
- /* All symbols from the same CD must be in a contiguous group. */
- static symTableItem symTable[] = {
- {"alg1", "one", "1", OM_SYM_alg1_one},
- {"alg1", "zero", "0", OM_SYM_alg1_zero},
- {"arith1", "abs", "abs", OM_SYM_arith1_abs},
- {"arith1", "divide", "/", OM_SYM_arith1_divide},
- {"arith1", "gcd", "gcd", OM_SYM_arith1_gcd},
- {"arith1", "lcm", "lcm", OM_SYM_arith1_lcm},
- {"arith1", "minus", "-", OM_SYM_arith1_minus},
- {"arith1", "plus", "+", OM_SYM_arith1_plus},
- {"arith1", "power", "**", OM_SYM_arith1_power},
- {"arith1", "product", "product", OM_SYM_arith1_product},
- {"arith1", "root", "nthRoot", OM_SYM_arith1_root},
- {"arith1", "sum", "summation", OM_SYM_arith1_sum},
- {"arith1", "times", "*", OM_SYM_arith1_times},
- {"arith1", "unary_minus", "-", OM_SYM_arith1_unary_minus},
- {"arith2", "arg", "argument", OM_SYM_arith2_arg},
- {"arith2", "inverse", "inv", OM_SYM_arith2_inverse},
- {"arith2", "times", "*", OM_SYM_arith2_times},
- {"bigfloat1", "bigfloat", "float", OM_SYM_bigfloat1_bigfloat},
- {"calculus1", "defint", "integrate", OM_SYM_calculus1_defint},
- {"calculus1", "diff", "differentiate", OM_SYM_calculus1_diff},
- /*MCDT*/
- {"calculus1", "int", "integrate", OM_SYM_calculus1_int},
- {"calculus1", "partialdiff", "differentiate", OM_SYM_calculus1_partialdiff},
- {"complex1", "argument", "argument", OM_SYM_complex1_argument},
- {"complex1", "complex_cartesian", "complex", OM_SYM_complex1_complex_cartesian},
- {"complex1", "complex_polar", "OMunhandledSymbol", OM_SYM_complex1_complex_polar},
- {"complex1", "conjugate", "conjugate", OM_SYM_complex1_conjugate},
- {"complex1", "real", "real", OM_SYM_complex1_real},
- {"complex1", "imaginary", "imaginary", OM_SYM_complex1_imaginary},
- /* dummy name: no equivalent Axiom function. */
- {"fns1", "identity", "OMunhandledSymbol", OM_SYM_fns1_identity},
- {"fns1", "range", "OMunhandledSymbol", OM_SYM_fns1_range},
- {"fns1", "image", "OMunhandledSymbol", OM_SYM_fns1_image},
- {"fns1", "domain", "OMunhandledSymbol", OM_SYM_fns1_domain},
- {"fns1", "inverse", "OMunhandledSymbol", OM_SYM_fns1_inverse},
- {"fns1", "lambda", "ADEF", OM_SYM_fns1_lambda},
- {"fns1", "left_compose", "ADEF", OM_SYM_fns1_left_compose},
- {"fns2", "apply_to_list", "reduce", OM_SYM_fns2_apply_to_list},
- {"fns2", "kernel", "OMunhandledSymbol", OM_SYM_fns2_kernel},
- /* FIXME: find out the axiom name for this. */
- /* {"fns2", "right_compose","????", OM_SYM_fns2_right_compose},*/
- {"integer1", "factorial", "factorial", OM_SYM_integer1_factorial},
- {"integer1", "factorof", "OMunhandledSymbol", OM_SYM_integer1_factorof},
- {"integer1", "quotient", "quo", OM_SYM_integer1_quotient},
- {"integer1", "rem", "rem", OM_SYM_integer1_remainder},
- {"interval1", "integer_interval", "segment", OM_SYM_interval1_integer_interval},
- {"interval1", "interval", "interval", OM_SYM_interval1_interval},
- {"interval1", "interval_cc", "interval", OM_SYM_interval1_interval_cc},
- {"interval1", "interval_co", "interval", OM_SYM_interval1_interval_co},
- {"interval1", "interval_oc", "interval", OM_SYM_interval1_interval_oc},
- {"interval1", "interval_oo", "interval", OM_SYM_interval1_interval_oo},
- {"limit1", "above", "right", OM_SYM_limit1_above},
- {"limit1", "below", "left", OM_SYM_limit1_below},
- {"limit1", "both_sides", "neither", OM_SYM_limit1_both_sides}, /* dummy name */
- {"limit1", "limit", "limit", OM_SYM_limit1_limit},
- {"limit1", "null", "neither", OM_SYM_limit1_null}, /* dummy name */
- {"linalg1", "determinant", "determinant", OM_SYM_linalg1_determinant},
- {"linalg1", "matrix_selector", "elt", OM_SYM_linalg1_matrix_selector},
- {"linalg1", "vector_selector", "elt", OM_SYM_linalg1_vector_selector},
- {"linalg1", "transpose", "transpose", OM_SYM_linalg1_transpose},
- {"linalg1", "outerproduct", "outerproduct", OM_SYM_linalg1_outerproduct},
- {"linalg1", "scalarproduct", "dot", OM_SYM_linalg1_scalarproduct},
- {"linalg1", "vectorproduct", "cross", OM_SYM_linalg1_vectorproduct},
- {"linalg2", "matrix", "matrix", OM_SYM_linalg2_matrix},
- {"linalg2", "matrixrow", "construct", OM_SYM_linalg2_matrixrow},
- {"linalg2", "vector", "vector", OM_SYM_linalg2_vector},
- {"linalg3", "matrix", "matrix", OM_SYM_linalg3_matrix},
- {"linalg3", "matrixcolumn", "construct", OM_SYM_linalg3_matrixcolumn},
- {"linalg3", "vector", "vector", OM_SYM_linalg3_vector},
- {"list1", "list", "construct", OM_SYM_list1_list},
- {"list1", "map", "map", OM_SYM_list1_map},
- {"list1", "suchthat", "select", OM_SYM_list1_suchthat},
- {"list2", "cons", "cons", OM_SYM_list2_cons},
- {"list2", "first", "first", OM_SYM_list2_first},
- {"list2", "rest", "rest", OM_SYM_list2_rest},
- {"logic1", "and", "and", OM_SYM_logic1_and},
- {"logic1", "false", "false", OM_SYM_logic1_false},
- {"logic1", "implies", "implies", OM_SYM_logic1_implies},
- {"logic1", "not", "not", OM_SYM_logic1_not},
- {"logic1", "or", "or", OM_SYM_logic1_or},
- {"logic1", "true", "true", OM_SYM_logic1_true},
- {"logic1", "xor", "xor", OM_SYM_logic1_xor},
- {"logic1", "equivalent", "OMunhandledSymbol", OM_SYM_logic1_equivalent},
- {"minmax1", "max", "max", OM_SYM_minmax1_max},
- {"minmax1", "min", "min", OM_SYM_minmax1_min},
- {"nums1", "based_integer", "OMunhandledSymbol", OM_SYM_nums1_based_integer},
- {"nums1", "e", "%e", OM_SYM_nums1_e},
- /* {"nums1", "gamma", "????", OM_SYM_nums1_gamma},*/
- {"nums1", "i", "%i", OM_SYM_nums1_i},
- {"nums1", "infinity", "%infinity", OM_SYM_nums1_infinity},
- {"nums1", "NaN", "OMunhandledSymbol", OM_SYM_nums1_NaN},
- {"nums1", "pi", "%pi", OM_SYM_nums1_pi},
- {"nums1", "rational", "/", OM_SYM_nums1_rational},
- {"relation1", "eq", "eq", OM_SYM_relation1_eq},
- {"relation1", "geq", ">=", OM_SYM_relation1_geq},
- {"relation1", "gt", ">", OM_SYM_relation1_gt},
- {"relation1", "leq", "<=", OM_SYM_relation1_leq},
- {"relation1", "lt", "<", OM_SYM_relation1_lt},
- {"relation1", "neq", "~=", OM_SYM_relation1_neq},
- {"relation1", "approx", "OMunhandledSymbol", OM_SYM_relation1_approx},
- {"rounding1", "ceiling", "ceiling", OM_SYM_rounding1_ceiling},
- {"rounding1", "floor", "floor", OM_SYM_rounding1_floor},
- {"rounding1", "trunc", "truncate", OM_SYM_rounding1_trunc},
- {"rounding1", "round", "round", OM_SYM_rounding1_round},
- /* FIXME: how to represent these in Axiom? */
- /* {"setname1", "C", "????", OM_SYM_setname1_C},*/
- /* {"setname1", "N", "????", OM_SYM_setname1_N},*/
- /* {"setname1", "P", "????", OM_SYM_setname1_P},*/
- /* {"setname1", "Q", "????", OM_SYM_setname1_Q},*/
- /* {"setname1", "R", "????", OM_SYM_setname1_R},*/
- /* {"setname1", "Z", "????", OM_SYM_setname1_Z},*/
- {"set1", "in", "member?", OM_SYM_set1_in},
- {"set1", "intersect", "intersect", OM_SYM_set1_intersect},
- /* This is the same as for "in" but will be combined with the "not" symbol. */
- {"set1", "notin", "member?", OM_SYM_set1_notin},
- /* This is the same as for "prsubset" but will be combined with the "not" symbol. */
- {"set1", "notprsubset", "<", OM_SYM_set1_notprsubset},
- /* This is the same as for "subset" but will be combined with the "not" symbol. */
- {"set1", "notsubset", "subset?", OM_SYM_set1_notsubset},
- {"set1", "prsubset", "<", OM_SYM_set1_prsubset},
- {"set1", "set", "set", OM_SYM_set1_set},
- {"set1", "setdiff", "difference", OM_SYM_set1_setdiff},
- {"set1", "subset", "subset?", OM_SYM_set1_subset},
- {"set1", "union", "union", OM_SYM_set1_union},
- {"set1", "size", "cardinality", OM_SYM_set1_size},
- {"set1", "cartesian_product", "OMunhandledSymbol", OM_SYM_set1_cartesian_product},
- {"set1", "emptyset", "empty", OM_SYM_set1_emptyset},
- {"set1", "map", "map", OM_SYM_set1_map},
- {"set1", "suchthat", "select", OM_SYM_set1_suchthat},
- {"transc1", "arccos", "acos", OM_SYM_transc1_arccos},
- {"transc1", "arcsin", "asin", OM_SYM_transc1_arcsin},
- {"transc1", "arctan", "atan", OM_SYM_transc1_arctan},
- {"transc1", "cos", "cos", OM_SYM_transc1_cos},
- {"transc1", "cosh", "cosh", OM_SYM_transc1_cosh},
- {"transc1", "cot", "cot", OM_SYM_transc1_cot},
- {"transc1", "coth", "coth", OM_SYM_transc1_coth},
- {"transc1", "csc", "csc", OM_SYM_transc1_csc},
- {"transc1", "csch", "csch", OM_SYM_transc1_csch},
- {"transc1", "exp", "exp", OM_SYM_transc1_exp},
- {"transc1", "ln", "log", OM_SYM_transc1_ln},
- {"transc1", "log", "log", OM_SYM_transc1_log},
- {"transc1", "sec", "sec", OM_SYM_transc1_sec},
- {"transc1", "sech", "sech", OM_SYM_transc1_sech},
- /*MCDT*/
- {"transc1", "sin", "sin", OM_SYM_transc1_sin},
- {"transc1", "sinh", "sinh", OM_SYM_transc1_sinh},
- {"transc1", "tan", "tan", OM_SYM_transc1_tan},
- {"transc1", "tanh", "tanh", OM_SYM_transc1_tanh},
- {"transc1", "arccosh", "acosh", OM_SYM_transc1_arccosh},
- {"transc1", "arccot", "acot", OM_SYM_transc1_arccot},
- {"transc1", "arccoth", "acoth", OM_SYM_transc1_arccoth},
- {"transc1", "arccsc", "acsc", OM_SYM_transc1_arccsc},
- {"transc1", "arccsch", "acsch", OM_SYM_transc1_arccsch},
- {"transc1", "arcsec", "asec", OM_SYM_transc1_arcsec},
- {"transc1", "arcsech", "asech", OM_SYM_transc1_arcsech},
- {"transc1", "arcsinh", "asinh", OM_SYM_transc1_arcsinh},
- {"transc1", "arctanh", "atanh", OM_SYM_transc1_arctanh},
- {NULL, NULL, NULL, OM_YYERROR}
- };
- int findOMSymbol(char *cd, char *name)
- {
- int i, j;
- /* First find the group of symbols from the correct CD. */
- i = 0;
- while (symTable[i].cd != NULL && strcmp(symTable[i].cd, cd) != 0)
- i++;
- if (symTable[i].cd == NULL)
- return -1;
- /* Now find the matching symbol from that group (if present). */
- j = i;
- while (symTable[j].cd != NULL) {
- if (strcmp(symTable[j].cd, symTable[i].cd) != 0)
- return -1;
- else if (strcmp(symTable[j].name, name) == 0)
- return j;
- else
- j++;
- }
- return -1;
- }
- YYSTYPE classifySymbol(Lisp_Object lsym)
- {
- Lisp_Object tmpObj;
- char *cd = NULL;
- char *name = NULL;
- int len;
- int i = 0;
- /*DEBUG*/
- /*Lprint(C_nil, lsym);*/
- /*END DEBUG*/
- /* Note: there is a strange serial dependency in the following code. If
- * the block which gets the CD of the symbol occurs before the block which
- * gets the name of the symbol, the symbol name will be corrupted in some
- * cases. Very odd. (VH) --- This may not be valid any more... */
- /* Get the name of the symbol. */
- /*tmpObj = om_getLispProperty(lsym, MkUndefSymM("name"));*/
- tmpObj = qcar(qcdr(lsym));
- /*DEBUG*/
- /*Lprint(C_nil, tmpObj);*/
- /*END DEBUG*/
- if (!stringp(tmpObj))
- return OM_YYERROR;
- name = get_string_data(tmpObj, "classifySymbol", &len);
- assert(name != NULL);
- name[len] = '\0';
- /* Get the CD of the symbol. */
- /*tmpObj = om_getLispProperty(lsym, MkUndefSymM("cd"));*/
- tmpObj = qcar(lsym);
- /*DEBUG*/
- #if defined(YYDEBUG) && YYDEBUG == 1
- Lprint(C_nil, tmpObj);
- #endif
- /*END DEBUG*/
- if (!stringp(tmpObj))
- return OM_YYERROR;
- cd = get_string_data(tmpObj, "classifySymbol", &len);
- assert(cd != NULL);
- cd[len] = '\0';
- /* Find the symbol in the symbol table, if it is present. */
- i = findOMSymbol(cd, name);
- /* If the symbol was recognised, return it. */
- if (i != -1) {
- yylval = StrToLspM(symTable[i].axname);
- return symTable[i].token;
- }
- else return OM_YYERROR;
- }
- int yyerror(char *msg)
- {
- fprintf(stderr, "ERROR: %s\n", msg);
- return 0;
- }
- YYSTYPE yylex()
- {
- OMtokenType ttype;
- OMstatus status;
- OMdev dev;
- dev = om_toDev(ldev);
- status = OMgetType(dev, &ttype);
- /* The following code breaks file handling. MCD */
- /* If we are listening to a socket (as opposed to reading from a file), we
- * should block until more tokens become available. */
- /* XXX
- if (OMisSocketDevice(dev)) {
- while (status == OMnoMoreToken)
- */
- status = OMgetType(dev, &ttype);
- /* XXX
- }
- */
- if (ttype == OMtokenUnknown || status != OMsuccess)
- return 0;
- else {
- switch (ttype) {
- case OMtokenApp:
- yylval = om_getApp(C_nil, ldev);
- return OM_APP;
- case OMtokenEndApp:
- yylval = om_getEndApp(C_nil, ldev);
- return OM_ENDAPP;
- case OMtokenAtp:
- yylval = om_getAtp(C_nil, ldev);
- return OM_ATP;
- case OMtokenEndAtp:
- yylval = om_getEndAtp(C_nil, ldev);
- return OM_ENDATP;
- case OMtokenAttr:
- yylval = om_getAttr(C_nil, ldev);
- return OM_ATTR;
- case OMtokenEndAttr:
- yylval = om_getEndAttr(C_nil, ldev);
- return OM_ENDATTR;
- case OMtokenBind:
- yylval = om_getBind(C_nil, ldev);
- return OM_BIND;
- case OMtokenEndBind:
- yylval = om_getEndBind(C_nil, ldev);
- return OM_ENDBIND;
- case OMtokenBVar:
- yylval = om_getBVar(C_nil, ldev);
- return OM_BVAR;
- case OMtokenEndBVar:
- yylval = om_getEndBVar(C_nil, ldev);
- return OM_ENDBVAR;
- case OMtokenError:
- yylval = om_getError(C_nil, ldev);
- return OM_ERROR;
- case OMtokenEndError:
- yylval = om_getEndError(C_nil, ldev);
- return OM_ENDERROR;
- case OMtokenObject:
- yylval = om_getObject(C_nil, ldev);
- return OM_OBJECT;
- case OMtokenEndObject:
- yylval = om_getEndObject(C_nil, ldev);
- return OM_ENDOBJECT;
- case OMtokenInt32:
- case OMtokenBigInt:
- yylval = om_getInt(C_nil, ldev);
- return OM_INT;
- case OMtokenFloat64:
- yylval = om_getFloat(C_nil, ldev);
- return OM_FLOAT;
- case OMtokenByteArray:
- yylval = om_getByteArray(C_nil, ldev);
- return OM_BYTEARRAY;
- case OMtokenVar:
- yylval = om_getVar(C_nil, ldev);
- return OM_VAR;
- case OMtokenString:
- yylval = om_getString(C_nil, ldev);
- return OM_STRING;
- case OMtokenSymbol:
- yylval = om_getSymbol(C_nil, ldev);
- return classifySymbol(yylval);
- default:
- return OM_YYERROR;
- }
- }
- }
- /**
- * This function is exposed to the lisp interpreter, to allow it to parse
- * OpenMath objects from a given string or device. The OpenMath object will be
- * returned in a form suitable for use by the "interpret" function.
- */
- Lisp_Object om_read(Lisp_Object nil, Lisp_Object obj)
- {
- OMdev dev;
- char *data = NULL;
- int len, val;
- CSL_IGNORE(nil);
- push(obj);
- inObj = nil;
- if (stringp(obj)) {
- data = get_string_data(obj, "om-read", &len);
- errexitn(1);
- if (data != NULL)
- data[len] = '\0';
- dev = OMmakeDevice(OMencodingXML, OMmakeIOString(&data));
- ldev = om_fromDev(dev);
- }
- else if (is_bignum(obj) && ((bignum_length(obj) >> 2) - 1) == 1)
- ldev = obj;
- else
- return aerror("om-read: argument must be a string or an OpenMath device.");
-
- /* Turn parser tracing on. */
- #if defined YYDEBUG && YYDEBUG == 1
- yydebug = 1;/*DEBUG*/
- #endif
- val = yyparse();
- yylval = C_nil;
- if (stringp(obj))
- OMcloseDevice(dev);
- errexitn(1);
- pop(obj);
- #if defined YYDEBUG && YYDEBUG == 1
- Lprint(C_nil, inObj);/*DEBUG*/
- #endif
- if (val == 0)
- return onevalue(inObj);
- else
- return aerror("om-read: invalid OpenMath object.");
- }
- /**
- * Will return the Lisp value true or false, depending on whether the named CD
- * (the lcd parameter) is supported by this phrasebook.
- */
- Lisp_Object om_supportsCD(Lisp_Object nil, Lisp_Object lcd)
- {
- char *cd = NULL;
- int len, i;
- CSL_IGNORE(nil);
- push(lcd);
- if (!stringp(lcd))
- return aerror("om-supportsCD: the argument must be a string");
- errexitn(1);
- cd = get_string_data(lcd, "om-supportsCD", &len);
- errexitn(1);
- if (cd == NULL)
- return aerror("om-supportsCD: invalid CD name");
- cd[len] = '\0';
- for (i = 0; symTable[i].cd != NULL; i++) {
- if (strcmp(symTable[i].cd, cd) == 0) {
- pop(lcd);
- return onevalue(StrToLspM("true"));
- }
- }
- pop(lcd);
- return onevalue(StrToLspM("false"));
- }
- /**
- * Will return Lisp true or false, depending on whether the named symbol from
- * the named CD is supported by this phrasebook.
- */
- Lisp_Object om_supportsSymbol(Lisp_Object nil, Lisp_Object lcd, Lisp_Object lsym)
- {
- char *cd = NULL;
- char *sym = NULL;
- int len, i;
- CSL_IGNORE(nil);
- push2(lcd, lsym);
- if (!stringp(lcd))
- return aerror("om-supportsSymbol: the content dictionary name must be a string");
- else if (!stringp(lsym))
- return aerror("om-supportsSymbol: the symbol name must be a string");
- errexitn(2);
- /* Note: there is a strange serial dependency in the following code. If
- * the block which gets the CD of the symbol occurs before the block which
- * gets the name of the symbol, the symbol name will be corrupted in some
- * cases. Very odd. (VH) */
- sym = get_string_data(lsym, "om-supportsSymbol received a corrupt symbol name", &len);
- errexitn(2);
- if (sym == NULL)
- return aerror("om-supportsSymbol: invalid symbol name");
- sym[len] = '\0';
- cd = get_string_data(lcd, "om-supportsSymbol received a corrupt CD name", &len);
- errexitn(2);
- if (cd == NULL)
- return aerror("om-supportsSymbol: invalid content dictionary name");
- cd[len] = '\0';
- pop2(lcd, lsym);
- i = findOMSymbol(cd, sym);
- if (i == -1)
- return onevalue(StrToLspM("false"));
- else
- return onevalue(StrToLspM("true"));
- }
- /**
- * Will return a list of the names of all CDs supported (partially or fully) by
- * this phrasebook.
- */
- Lisp_Object MS_CDECL om_listCDs(Lisp_Object nil, int nargs, ...)
- {
- Lisp_Object lcds = nil;
- Lisp_Object obj;
- int i, j;
- CSL_IGNORE(nil);
- argcheck(nargs, 0, "om-listCDs: this function takes no arguments");
- /* Find the end of the symbol table. */
- for (i = 0; symTable[i].cd != NULL; i++) ;
- /* Work backwards through the symbol table, consing new CD names into the
- * list as they are encountered. */
- j = i;
- while (i > 0) {
- i--;
- if (symTable[j].cd == NULL && symTable[i].cd != NULL)
- j = i;
- else if (strcmp(symTable[i].cd, symTable[j].cd) != 0)
- j = i;
- if (j == i) {
- lcds = cons(make_string(symTable[i].cd), lcds);
- errexit();
- }
- }
- obj = StrToLspM("construct");
- errexit();
- lcds = cons(obj, lcds);
- errexit();
- return onevalue(lcds);
- }
- /**
- * Will return a list of all of the symbols from the named CD that are
- * supported by this phrasebook.
- */
- Lisp_Object om_listSymbols(Lisp_Object nil, Lisp_Object lcd)
- {
- Lisp_Object lsyms = nil;
- Lisp_Object obj;
- char *cd = NULL;
- int i, j, len;
-
- CSL_IGNORE(nil);
- push(lcd);
- if (!stringp(lcd))
- return aerror("om-listSymbols: the content dictionary name must be a string");
- errexitn(1);
- cd = get_string_data(lcd, "om-listSymbols", &len);
- errexitn(1);
- if (cd == NULL)
- return aerror("om-listSymbols: invalid content dictionary name");
- cd[len] = '\0';
- for (i = 0; symTable[i].cd != NULL; i++) {
- if (strcmp(symTable[i].cd, cd) == 0)
- break;
- }
- if (symTable[i].cd == NULL) {
- pop(lcd);
- return nil;
- }
-
- for (j = i + 1; symTable[j].cd != NULL; j++) {
- if (strcmp(symTable[j].cd, cd) != 0)
- break;
- }
- for (j = j - 1; j >= i; j--) {
- lsyms = cons(make_string(symTable[j].name), lsyms);
- errexitn(1);
- }
- obj = StrToLspM("construct");
- errexitn(1);
- lsyms = cons(obj, lsyms);
- errexitn(1);
- pop(lcd);
- return onevalue(lsyms);
- }
- /**
- * This will return a list of the supported CDs that include the symbol with the
- * given name.
- */
- Lisp_Object om_whichCDs(Lisp_Object nil, Lisp_Object lsym)
- {
- Lisp_Object lcds = nil;
- Lisp_Object obj = nil;
- char *sym = NULL;
- int i, len;
- CSL_IGNORE(nil);
- push(lsym);
- if (!stringp(lsym))
- return aerror("om-whichCDs: symbol name must be a string");
- errexitn(1);
- sym = get_string_data(lsym, "om-whichCDs", &len);
- errexitn(1);
- if (sym == NULL)
- return aerror("om-whichCDs: invalid symbol name");
- sym[len] = '\0';
- /* Find the end of the symbol table. */
- for (i = 0; symTable[i].cd != NULL; i++) ;
- while (i > 0) {
- i--;
- if (strcmp(symTable[i].name, sym) == 0) {
- lcds = cons(make_string(symTable[i].cd), lcds);
- errexitn(1);
- }
- }
- obj = StrToLspM("construct");
- errexitn(1);
- lcds = cons(obj, lcds);
- errexitn(1);
- pop(lsym);
- return onevalue(lcds);
- }
|