1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709 |
- diff --exclude CVS -urN genext2fs-1.3.orig/AUTHORS genext2fs/AUTHORS
- --- genext2fs-1.3.orig/AUTHORS 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/AUTHORS 2001-05-02 12:20:05.000000000 -0600
- @@ -0,0 +1 @@
- +Xavier Bestel <xavier.bestel@free.fr>
- diff --exclude CVS -urN genext2fs-1.3.orig/ChangeLog genext2fs/ChangeLog
- --- genext2fs-1.3.orig/ChangeLog 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/ChangeLog 2004-11-21 23:21:05.000000000 -0700
- @@ -0,0 +1,2 @@
- +see our cvs logs here:
- +http://cvs.sourceforge.net/viewcvs.py/genext2fs/genext2fs/
- diff --exclude CVS -urN genext2fs-1.3.orig/INSTALL genext2fs/INSTALL
- --- genext2fs-1.3.orig/INSTALL 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/INSTALL 2004-11-21 23:19:19.000000000 -0700
- @@ -0,0 +1,5 @@
- +To install, just do it the normal GNU way:
- +
- +./configure
- +make
- +sudo make install
- diff --exclude CVS -urN genext2fs-1.3.orig/Makefile.am genext2fs/Makefile.am
- --- genext2fs-1.3.orig/Makefile.am 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/Makefile.am 2002-10-16 09:41:00.000000000 -0600
- @@ -0,0 +1,11 @@
- +bin_PROGRAMS = genext2fs
- +genext2fs_SOURCES = genext2fs.c
- +man_MANS = genext2fs.8
- +
- +# test genext2fs by creating the image and comparing checksums
- +test: all
- + sh ./test.sh
- +
- +# test genext2fs by actually mounting the created image.
- +test-mount: all
- + sudo sh ./test-mount.sh
- diff --exclude CVS -urN genext2fs-1.3.orig/Makefile.in genext2fs/Makefile.in
- --- genext2fs-1.3.orig/Makefile.in 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/Makefile.in 2004-12-27 13:03:47.000000000 -0700
- @@ -0,0 +1,570 @@
- +# Makefile.in generated by automake 1.8.5 from Makefile.am.
- +# @configure_input@
- +
- +# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
- +# 2003, 2004 Free Software Foundation, Inc.
- +# This Makefile.in is free software; the Free Software Foundation
- +# gives unlimited permission to copy and/or distribute it,
- +# with or without modifications, as long as this notice is preserved.
- +
- +# This program is distributed in the hope that it will be useful,
- +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
- +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
- +# PARTICULAR PURPOSE.
- +
- +@SET_MAKE@
- +
- +SOURCES = $(genext2fs_SOURCES)
- +
- +srcdir = @srcdir@
- +top_srcdir = @top_srcdir@
- +VPATH = @srcdir@
- +pkgdatadir = $(datadir)/@PACKAGE@
- +pkglibdir = $(libdir)/@PACKAGE@
- +pkgincludedir = $(includedir)/@PACKAGE@
- +top_builddir = .
- +am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
- +INSTALL = @INSTALL@
- +install_sh_DATA = $(install_sh) -c -m 644
- +install_sh_PROGRAM = $(install_sh) -c
- +install_sh_SCRIPT = $(install_sh) -c
- +INSTALL_HEADER = $(INSTALL_DATA)
- +transform = $(program_transform_name)
- +NORMAL_INSTALL = :
- +PRE_INSTALL = :
- +POST_INSTALL = :
- +NORMAL_UNINSTALL = :
- +PRE_UNINSTALL = :
- +POST_UNINSTALL = :
- +bin_PROGRAMS = genext2fs$(EXEEXT)
- +subdir = .
- +DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \
- + $(srcdir)/Makefile.in $(top_srcdir)/configure AUTHORS COPYING \
- + ChangeLog INSTALL NEWS TODO depcomp install-sh missing
- +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
- +am__aclocal_m4_deps = $(top_srcdir)/configure.in
- +am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
- + $(ACLOCAL_M4)
- +am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
- + configure.lineno configure.status.lineno
- +mkinstalldirs = $(mkdir_p)
- +CONFIG_CLEAN_FILES =
- +am__installdirs = "$(DESTDIR)$(bindir)" "$(DESTDIR)$(man8dir)"
- +binPROGRAMS_INSTALL = $(INSTALL_PROGRAM)
- +PROGRAMS = $(bin_PROGRAMS)
- +am_genext2fs_OBJECTS = genext2fs.$(OBJEXT)
- +genext2fs_OBJECTS = $(am_genext2fs_OBJECTS)
- +genext2fs_LDADD = $(LDADD)
- +DEFAULT_INCLUDES = -I. -I$(srcdir)
- +depcomp = $(SHELL) $(top_srcdir)/depcomp
- +am__depfiles_maybe = depfiles
- +@AMDEP_TRUE@DEP_FILES = ./$(DEPDIR)/genext2fs.Po
- +COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
- + $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
- +CCLD = $(CC)
- +LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
- +SOURCES = $(genext2fs_SOURCES)
- +DIST_SOURCES = $(genext2fs_SOURCES)
- +man8dir = $(mandir)/man8
- +NROFF = nroff
- +MANS = $(man_MANS)
- +ETAGS = etags
- +CTAGS = ctags
- +DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
- +distdir = $(PACKAGE)-$(VERSION)
- +top_distdir = $(distdir)
- +am__remove_distdir = \
- + { test ! -d $(distdir) \
- + || { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \
- + && rm -fr $(distdir); }; }
- +DIST_ARCHIVES = $(distdir).tar.gz
- +GZIP_ENV = --best
- +distuninstallcheck_listfiles = find . -type f -print
- +distcleancheck_listfiles = find . -type f -print
- +ACLOCAL = @ACLOCAL@
- +AMDEP_FALSE = @AMDEP_FALSE@
- +AMDEP_TRUE = @AMDEP_TRUE@
- +AMTAR = @AMTAR@
- +AUTOCONF = @AUTOCONF@
- +AUTOHEADER = @AUTOHEADER@
- +AUTOMAKE = @AUTOMAKE@
- +AWK = @AWK@
- +CC = @CC@
- +CCDEPMODE = @CCDEPMODE@
- +CFLAGS = @CFLAGS@
- +CPPFLAGS = @CPPFLAGS@
- +CYGPATH_W = @CYGPATH_W@
- +DEFS = @DEFS@
- +DEPDIR = @DEPDIR@
- +ECHO_C = @ECHO_C@
- +ECHO_N = @ECHO_N@
- +ECHO_T = @ECHO_T@
- +EXEEXT = @EXEEXT@
- +INSTALL_DATA = @INSTALL_DATA@
- +INSTALL_PROGRAM = @INSTALL_PROGRAM@
- +INSTALL_SCRIPT = @INSTALL_SCRIPT@
- +INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
- +LDFLAGS = @LDFLAGS@
- +LIBOBJS = @LIBOBJS@
- +LIBS = @LIBS@
- +LTLIBOBJS = @LTLIBOBJS@
- +MAKEINFO = @MAKEINFO@
- +OBJEXT = @OBJEXT@
- +PACKAGE = @PACKAGE@
- +PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
- +PACKAGE_NAME = @PACKAGE_NAME@
- +PACKAGE_STRING = @PACKAGE_STRING@
- +PACKAGE_TARNAME = @PACKAGE_TARNAME@
- +PACKAGE_VERSION = @PACKAGE_VERSION@
- +PATH_SEPARATOR = @PATH_SEPARATOR@
- +SET_MAKE = @SET_MAKE@
- +SHELL = @SHELL@
- +STRIP = @STRIP@
- +VERSION = @VERSION@
- +ac_ct_CC = @ac_ct_CC@
- +ac_ct_STRIP = @ac_ct_STRIP@
- +am__fastdepCC_FALSE = @am__fastdepCC_FALSE@
- +am__fastdepCC_TRUE = @am__fastdepCC_TRUE@
- +am__include = @am__include@
- +am__leading_dot = @am__leading_dot@
- +am__quote = @am__quote@
- +bindir = @bindir@
- +build_alias = @build_alias@
- +datadir = @datadir@
- +exec_prefix = @exec_prefix@
- +host_alias = @host_alias@
- +includedir = @includedir@
- +infodir = @infodir@
- +install_sh = @install_sh@
- +libdir = @libdir@
- +libexecdir = @libexecdir@
- +localstatedir = @localstatedir@
- +mandir = @mandir@
- +mkdir_p = @mkdir_p@
- +oldincludedir = @oldincludedir@
- +prefix = @prefix@
- +program_transform_name = @program_transform_name@
- +sbindir = @sbindir@
- +sharedstatedir = @sharedstatedir@
- +sysconfdir = @sysconfdir@
- +target_alias = @target_alias@
- +genext2fs_SOURCES = genext2fs.c
- +man_MANS = genext2fs.8
- +all: all-am
- +
- +.SUFFIXES:
- +.SUFFIXES: .c .o .obj
- +am--refresh:
- + @:
- +$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
- + @for dep in $?; do \
- + case '$(am__configure_deps)' in \
- + *$$dep*) \
- + echo ' cd $(srcdir) && $(AUTOMAKE) --gnu '; \
- + cd $(srcdir) && $(AUTOMAKE) --gnu \
- + && exit 0; \
- + exit 1;; \
- + esac; \
- + done; \
- + echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \
- + cd $(top_srcdir) && \
- + $(AUTOMAKE) --gnu Makefile
- +.PRECIOUS: Makefile
- +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
- + @case '$?' in \
- + *config.status*) \
- + echo ' $(SHELL) ./config.status'; \
- + $(SHELL) ./config.status;; \
- + *) \
- + echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
- + cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
- + esac;
- +
- +$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
- + $(SHELL) ./config.status --recheck
- +
- +$(top_srcdir)/configure: $(am__configure_deps)
- + cd $(srcdir) && $(AUTOCONF)
- +$(ACLOCAL_M4): $(am__aclocal_m4_deps)
- + cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
- +install-binPROGRAMS: $(bin_PROGRAMS)
- + @$(NORMAL_INSTALL)
- + test -z "$(bindir)" || $(mkdir_p) "$(DESTDIR)$(bindir)"
- + @list='$(bin_PROGRAMS)'; for p in $$list; do \
- + p1=`echo $$p|sed 's/$(EXEEXT)$$//'`; \
- + if test -f $$p \
- + ; then \
- + f=`echo "$$p1" | sed 's,^.*/,,;$(transform);s/$$/$(EXEEXT)/'`; \
- + echo " $(INSTALL_PROGRAM_ENV) $(binPROGRAMS_INSTALL) '$$p' '$(DESTDIR)$(bindir)/$$f'"; \
- + $(INSTALL_PROGRAM_ENV) $(binPROGRAMS_INSTALL) "$$p" "$(DESTDIR)$(bindir)/$$f" || exit 1; \
- + else :; fi; \
- + done
- +
- +uninstall-binPROGRAMS:
- + @$(NORMAL_UNINSTALL)
- + @list='$(bin_PROGRAMS)'; for p in $$list; do \
- + f=`echo "$$p" | sed 's,^.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/'`; \
- + echo " rm -f '$(DESTDIR)$(bindir)/$$f'"; \
- + rm -f "$(DESTDIR)$(bindir)/$$f"; \
- + done
- +
- +clean-binPROGRAMS:
- + -test -z "$(bin_PROGRAMS)" || rm -f $(bin_PROGRAMS)
- +genext2fs$(EXEEXT): $(genext2fs_OBJECTS) $(genext2fs_DEPENDENCIES)
- + @rm -f genext2fs$(EXEEXT)
- + $(LINK) $(genext2fs_LDFLAGS) $(genext2fs_OBJECTS) $(genext2fs_LDADD) $(LIBS)
- +
- +mostlyclean-compile:
- + -rm -f *.$(OBJEXT)
- +
- +distclean-compile:
- + -rm -f *.tab.c
- +
- +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/genext2fs.Po@am__quote@
- +
- +.c.o:
- +@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \
- +@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
- +@am__fastdepCC_FALSE@ $(COMPILE) -c $<
- +
- +.c.obj:
- +@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \
- +@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ depfile='$(DEPDIR)/$*.Po' tmpdepfile='$(DEPDIR)/$*.TPo' @AMDEPBACKSLASH@
- +@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
- +@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'`
- +uninstall-info-am:
- +install-man8: $(man8_MANS) $(man_MANS)
- + @$(NORMAL_INSTALL)
- + test -z "$(man8dir)" || $(mkdir_p) "$(DESTDIR)$(man8dir)"
- + @list='$(man8_MANS) $(dist_man8_MANS) $(nodist_man8_MANS)'; \
- + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \
- + for i in $$l2; do \
- + case "$$i" in \
- + *.8*) list="$$list $$i" ;; \
- + esac; \
- + done; \
- + for i in $$list; do \
- + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \
- + else file=$$i; fi; \
- + ext=`echo $$i | sed -e 's/^.*\\.//'`; \
- + case "$$ext" in \
- + 8*) ;; \
- + *) ext='8' ;; \
- + esac; \
- + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \
- + inst=`echo $$inst | sed -e 's/^.*\///'`; \
- + inst=`echo $$inst | sed '$(transform)'`.$$ext; \
- + echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man8dir)/$$inst'"; \
- + $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man8dir)/$$inst"; \
- + done
- +uninstall-man8:
- + @$(NORMAL_UNINSTALL)
- + @list='$(man8_MANS) $(dist_man8_MANS) $(nodist_man8_MANS)'; \
- + l2='$(man_MANS) $(dist_man_MANS) $(nodist_man_MANS)'; \
- + for i in $$l2; do \
- + case "$$i" in \
- + *.8*) list="$$list $$i" ;; \
- + esac; \
- + done; \
- + for i in $$list; do \
- + ext=`echo $$i | sed -e 's/^.*\\.//'`; \
- + case "$$ext" in \
- + 8*) ;; \
- + *) ext='8' ;; \
- + esac; \
- + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \
- + inst=`echo $$inst | sed -e 's/^.*\///'`; \
- + inst=`echo $$inst | sed '$(transform)'`.$$ext; \
- + echo " rm -f '$(DESTDIR)$(man8dir)/$$inst'"; \
- + rm -f "$(DESTDIR)$(man8dir)/$$inst"; \
- + done
- +
- +ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
- + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
- + unique=`for i in $$list; do \
- + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
- + done | \
- + $(AWK) ' { files[$$0] = 1; } \
- + END { for (i in files) print i; }'`; \
- + mkid -fID $$unique
- +tags: TAGS
- +
- +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
- + $(TAGS_FILES) $(LISP)
- + tags=; \
- + here=`pwd`; \
- + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
- + unique=`for i in $$list; do \
- + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
- + done | \
- + $(AWK) ' { files[$$0] = 1; } \
- + END { for (i in files) print i; }'`; \
- + if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \
- + test -n "$$unique" || unique=$$empty_fix; \
- + $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
- + $$tags $$unique; \
- + fi
- +ctags: CTAGS
- +CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
- + $(TAGS_FILES) $(LISP)
- + tags=; \
- + here=`pwd`; \
- + list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
- + unique=`for i in $$list; do \
- + if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
- + done | \
- + $(AWK) ' { files[$$0] = 1; } \
- + END { for (i in files) print i; }'`; \
- + test -z "$(CTAGS_ARGS)$$tags$$unique" \
- + || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
- + $$tags $$unique
- +
- +GTAGS:
- + here=`$(am__cd) $(top_builddir) && pwd` \
- + && cd $(top_srcdir) \
- + && gtags -i $(GTAGS_ARGS) $$here
- +
- +distclean-tags:
- + -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
- +
- +distdir: $(DISTFILES)
- + $(am__remove_distdir)
- + mkdir $(distdir)
- + @srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \
- + topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \
- + list='$(DISTFILES)'; for file in $$list; do \
- + case $$file in \
- + $(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \
- + $(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \
- + esac; \
- + if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
- + dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
- + if test "$$dir" != "$$file" && test "$$dir" != "."; then \
- + dir="/$$dir"; \
- + $(mkdir_p) "$(distdir)$$dir"; \
- + else \
- + dir=''; \
- + fi; \
- + if test -d $$d/$$file; then \
- + if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
- + cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
- + fi; \
- + cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
- + else \
- + test -f $(distdir)/$$file \
- + || cp -p $$d/$$file $(distdir)/$$file \
- + || exit 1; \
- + fi; \
- + done
- + -find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \
- + ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
- + ! -type d ! -perm -400 -exec chmod a+r {} \; -o \
- + ! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \
- + || chmod -R a+r $(distdir)
- +dist-gzip: distdir
- + $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
- + $(am__remove_distdir)
- +
- +dist-bzip2: distdir
- + $(AMTAR) chof - $(distdir) | bzip2 -9 -c >$(distdir).tar.bz2
- + $(am__remove_distdir)
- +
- +dist-tarZ: distdir
- + $(AMTAR) chof - $(distdir) | compress -c >$(distdir).tar.Z
- + $(am__remove_distdir)
- +
- +dist-shar: distdir
- + shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz
- + $(am__remove_distdir)
- +
- +dist-zip: distdir
- + -rm -f $(distdir).zip
- + zip -rq $(distdir).zip $(distdir)
- + $(am__remove_distdir)
- +
- +dist dist-all: distdir
- + $(AMTAR) chof - $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
- + $(am__remove_distdir)
- +
- +# This target untars the dist file and tries a VPATH configuration. Then
- +# it guarantees that the distribution is self-contained by making another
- +# tarfile.
- +distcheck: dist
- + case '$(DIST_ARCHIVES)' in \
- + *.tar.gz*) \
- + GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(AMTAR) xf - ;;\
- + *.tar.bz2*) \
- + bunzip2 -c $(distdir).tar.bz2 | $(AMTAR) xf - ;;\
- + *.tar.Z*) \
- + uncompress -c $(distdir).tar.Z | $(AMTAR) xf - ;;\
- + *.shar.gz*) \
- + GZIP=$(GZIP_ENV) gunzip -c $(distdir).shar.gz | unshar ;;\
- + *.zip*) \
- + unzip $(distdir).zip ;;\
- + esac
- + chmod -R a-w $(distdir); chmod a+w $(distdir)
- + mkdir $(distdir)/_build
- + mkdir $(distdir)/_inst
- + chmod a-w $(distdir)
- + dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \
- + && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \
- + && cd $(distdir)/_build \
- + && ../configure --srcdir=.. --prefix="$$dc_install_base" \
- + $(DISTCHECK_CONFIGURE_FLAGS) \
- + && $(MAKE) $(AM_MAKEFLAGS) \
- + && $(MAKE) $(AM_MAKEFLAGS) dvi \
- + && $(MAKE) $(AM_MAKEFLAGS) check \
- + && $(MAKE) $(AM_MAKEFLAGS) install \
- + && $(MAKE) $(AM_MAKEFLAGS) installcheck \
- + && $(MAKE) $(AM_MAKEFLAGS) uninstall \
- + && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \
- + distuninstallcheck \
- + && chmod -R a-w "$$dc_install_base" \
- + && ({ \
- + (cd ../.. && umask 077 && mkdir "$$dc_destdir") \
- + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \
- + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \
- + && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \
- + distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \
- + } || { rm -rf "$$dc_destdir"; exit 1; }) \
- + && rm -rf "$$dc_destdir" \
- + && $(MAKE) $(AM_MAKEFLAGS) dist \
- + && rm -rf $(DIST_ARCHIVES) \
- + && $(MAKE) $(AM_MAKEFLAGS) distcleancheck
- + $(am__remove_distdir)
- + @(echo "$(distdir) archives ready for distribution: "; \
- + list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \
- + sed -e '1{h;s/./=/g;p;x;}' -e '$${p;x;}'
- +distuninstallcheck:
- + @cd $(distuninstallcheck_dir) \
- + && test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \
- + || { echo "ERROR: files left after uninstall:" ; \
- + if test -n "$(DESTDIR)"; then \
- + echo " (check DESTDIR support)"; \
- + fi ; \
- + $(distuninstallcheck_listfiles) ; \
- + exit 1; } >&2
- +distcleancheck: distclean
- + @if test '$(srcdir)' = . ; then \
- + echo "ERROR: distcleancheck can only run from a VPATH build" ; \
- + exit 1 ; \
- + fi
- + @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
- + || { echo "ERROR: files left in build directory after distclean:" ; \
- + $(distcleancheck_listfiles) ; \
- + exit 1; } >&2
- +check-am: all-am
- +check: check-am
- +all-am: Makefile $(PROGRAMS) $(MANS)
- +installdirs:
- + for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(man8dir)"; do \
- + test -z "$$dir" || $(mkdir_p) "$$dir"; \
- + done
- +install: install-am
- +install-exec: install-exec-am
- +install-data: install-data-am
- +uninstall: uninstall-am
- +
- +install-am: all-am
- + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
- +
- +installcheck: installcheck-am
- +install-strip:
- + $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
- + install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
- + `test -z '$(STRIP)' || \
- + echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
- +mostlyclean-generic:
- +
- +clean-generic:
- +
- +distclean-generic:
- + -rm -f $(CONFIG_CLEAN_FILES)
- +
- +maintainer-clean-generic:
- + @echo "This command is intended for maintainers to use"
- + @echo "it deletes files that may require special tools to rebuild."
- +clean: clean-am
- +
- +clean-am: clean-binPROGRAMS clean-generic mostlyclean-am
- +
- +distclean: distclean-am
- + -rm -f $(am__CONFIG_DISTCLEAN_FILES)
- + -rm -rf ./$(DEPDIR)
- + -rm -f Makefile
- +distclean-am: clean-am distclean-compile distclean-generic \
- + distclean-tags
- +
- +dvi: dvi-am
- +
- +dvi-am:
- +
- +html: html-am
- +
- +info: info-am
- +
- +info-am:
- +
- +install-data-am: install-man
- +
- +install-exec-am: install-binPROGRAMS
- +
- +install-info: install-info-am
- +
- +install-man: install-man8
- +
- +installcheck-am:
- +
- +maintainer-clean: maintainer-clean-am
- + -rm -f $(am__CONFIG_DISTCLEAN_FILES)
- + -rm -rf $(top_srcdir)/autom4te.cache
- + -rm -rf ./$(DEPDIR)
- + -rm -f Makefile
- +maintainer-clean-am: distclean-am maintainer-clean-generic
- +
- +mostlyclean: mostlyclean-am
- +
- +mostlyclean-am: mostlyclean-compile mostlyclean-generic
- +
- +pdf: pdf-am
- +
- +pdf-am:
- +
- +ps: ps-am
- +
- +ps-am:
- +
- +uninstall-am: uninstall-binPROGRAMS uninstall-info-am uninstall-man
- +
- +uninstall-man: uninstall-man8
- +
- +.PHONY: CTAGS GTAGS all all-am am--refresh check check-am clean \
- + clean-binPROGRAMS clean-generic ctags dist dist-all dist-bzip2 \
- + dist-gzip dist-shar dist-tarZ dist-zip distcheck distclean \
- + distclean-compile distclean-generic distclean-tags \
- + distcleancheck distdir distuninstallcheck dvi dvi-am html \
- + html-am info info-am install install-am install-binPROGRAMS \
- + install-data install-data-am install-exec install-exec-am \
- + install-info install-info-am install-man install-man8 \
- + install-strip installcheck installcheck-am installdirs \
- + maintainer-clean maintainer-clean-generic mostlyclean \
- + mostlyclean-compile mostlyclean-generic pdf pdf-am ps ps-am \
- + tags uninstall uninstall-am uninstall-binPROGRAMS \
- + uninstall-info-am uninstall-man uninstall-man8
- +
- +
- +# test genext2fs by creating the image and comparing checksums
- +test: all
- + sh ./test.sh
- +
- +# test genext2fs by actually mounting the created image.
- +test-mount: all
- + sudo sh ./test-mount.sh
- +# Tell versions [3.59,3.63) of GNU make to not export all variables.
- +# Otherwise a system limit (for SysV at least) may be exceeded.
- +.NOEXPORT:
- diff --exclude CVS -urN genext2fs-1.3.orig/NEWS genext2fs/NEWS
- --- genext2fs-1.3.orig/NEWS 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/NEWS 2004-11-21 23:21:05.000000000 -0700
- @@ -0,0 +1 @@
- +No news yet :)
- diff --exclude CVS -urN genext2fs-1.3.orig/README genext2fs/README
- --- genext2fs-1.3.orig/README 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/README 2004-11-21 23:18:40.000000000 -0700
- @@ -0,0 +1,19 @@
- + ABOUT
- +-----------
- +genext2fs is a mean to generate an ext2 filesystem as a normal (non-root)
- +user. It doesn't require you to mount the image file to copy files on it.
- +It doesn't even require you to be the superuser to make device nodes.
- +
- +http://sourceforge.net/projects/genext2fs
- +
- + CONTACT
- +-------------
- +Please use the genext2fs-devel@lists.sourceforge.net mailing list.
- +
- + INSTALL
- +-------------
- +Please see the INSTALL file ;)
- +
- + AUTHORS
- +-------------
- +Please see the AUTHORS file ;)
- diff --exclude CVS -urN genext2fs-1.3.orig/TODO genext2fs/TODO
- --- genext2fs-1.3.orig/TODO 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/TODO 2004-11-25 11:12:10.000000000 -0700
- @@ -0,0 +1,13 @@
- +Disclaimer: I'll probably never do all this ...
- +
- +- support fancy ext2 options
- +- support ext3
- +
- +- add path to -f/-d options, e.g:
- + -f /:file.img => extract file.img at root
- + -d /etc:/path/to/my/etc => copy /path/to/my/etc into /etc
- +
- +- add tar.gz extraction capabilities ?
- +
- +- implement truncate_node
- +- find a better way to guess filesystem's size
- diff --exclude CVS -urN genext2fs-1.3.orig/aclocal.m4 genext2fs/aclocal.m4
- --- genext2fs-1.3.orig/aclocal.m4 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/aclocal.m4 2004-12-27 13:03:45.000000000 -0700
- @@ -0,0 +1,908 @@
- +# generated automatically by aclocal 1.8.5 -*- Autoconf -*-
- +
- +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004
- +# Free Software Foundation, Inc.
- +# This file is free software; the Free Software Foundation
- +# gives unlimited permission to copy and/or distribute it,
- +# with or without modifications, as long as this notice is preserved.
- +
- +# This program is distributed in the hope that it will be useful,
- +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
- +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
- +# PARTICULAR PURPOSE.
- +
- +# -*- Autoconf -*-
- +# Copyright (C) 2002, 2003 Free Software Foundation, Inc.
- +# Generated from amversion.in; do not edit by hand.
- +
- +# 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
- +
- +# AM_AUTOMAKE_VERSION(VERSION)
- +# ----------------------------
- +# Automake X.Y traces this macro to ensure aclocal.m4 has been
- +# generated from the m4 files accompanying Automake X.Y.
- +AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version="1.8"])
- +
- +# AM_SET_CURRENT_AUTOMAKE_VERSION
- +# -------------------------------
- +# Call AM_AUTOMAKE_VERSION so it can be traced.
- +# This function is AC_REQUIREd by AC_INIT_AUTOMAKE.
- +AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
- + [AM_AUTOMAKE_VERSION([1.8.5])])
- +
- +# AM_AUX_DIR_EXPAND
- +
- +# Copyright (C) 2001, 2003 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.
- +
- +# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
- +# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to
- +# `$srcdir', `$srcdir/..', or `$srcdir/../..'.
- +#
- +# Of course, Automake must honor this variable whenever it calls a
- +# tool from the auxiliary directory. The problem is that $srcdir (and
- +# therefore $ac_aux_dir as well) can be either absolute or relative,
- +# depending on how configure is run. This is pretty annoying, since
- +# it makes $ac_aux_dir quite unusable in subdirectories: in the top
- +# source directory, any form will work fine, but in subdirectories a
- +# relative path needs to be adjusted first.
- +#
- +# $ac_aux_dir/missing
- +# fails when called from a subdirectory if $ac_aux_dir is relative
- +# $top_srcdir/$ac_aux_dir/missing
- +# fails if $ac_aux_dir is absolute,
- +# fails when called from a subdirectory in a VPATH build with
- +# a relative $ac_aux_dir
- +#
- +# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
- +# are both prefixed by $srcdir. In an in-source build this is usually
- +# harmless because $srcdir is `.', but things will broke when you
- +# start a VPATH build or use an absolute $srcdir.
- +#
- +# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
- +# iff we strip the leading $srcdir from $ac_aux_dir. That would be:
- +# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
- +# and then we would define $MISSING as
- +# MISSING="\${SHELL} $am_aux_dir/missing"
- +# This will work as long as MISSING is not called from configure, because
- +# unfortunately $(top_srcdir) has no meaning in configure.
- +# However there are other variables, like CC, which are often used in
- +# configure, and could therefore not use this "fixed" $ac_aux_dir.
- +#
- +# Another solution, used here, is to always expand $ac_aux_dir to an
- +# absolute PATH. The drawback is that using absolute paths prevent a
- +# configured tree to be moved without reconfiguration.
- +
- +AC_DEFUN([AM_AUX_DIR_EXPAND],
- +[dnl Rely on autoconf to set up CDPATH properly.
- +AC_PREREQ([2.50])dnl
- +# expand $ac_aux_dir to an absolute path
- +am_aux_dir=`cd $ac_aux_dir && pwd`
- +])
- +
- +# AM_CONDITIONAL -*- Autoconf -*-
- +
- +# Copyright (C) 1997, 2000, 2001, 2003 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.
- +
- +# serial 6
- +
- +# AM_CONDITIONAL(NAME, SHELL-CONDITION)
- +# -------------------------------------
- +# Define a conditional.
- +AC_DEFUN([AM_CONDITIONAL],
- +[AC_PREREQ(2.52)dnl
- + ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])],
- + [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
- +AC_SUBST([$1_TRUE])
- +AC_SUBST([$1_FALSE])
- +if $2; then
- + $1_TRUE=
- + $1_FALSE='#'
- +else
- + $1_TRUE='#'
- + $1_FALSE=
- +fi
- +AC_CONFIG_COMMANDS_PRE(
- +[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
- + AC_MSG_ERROR([conditional "$1" was never defined.
- +Usually this means the macro was only invoked conditionally.])
- +fi])])
- +
- +# serial 7 -*- Autoconf -*-
- +
- +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004
- +# 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.
- +
- +
- +# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
- +# written in clear, in which case automake, when reading aclocal.m4,
- +# will think it sees a *use*, and therefore will trigger all it's
- +# C support machinery. Also note that it means that autoscan, seeing
- +# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
- +
- +
- +
- +# _AM_DEPENDENCIES(NAME)
- +# ----------------------
- +# See how the compiler implements dependency checking.
- +# NAME is "CC", "CXX", "GCJ", or "OBJC".
- +# We try a few techniques and use that to set a single cache variable.
- +#
- +# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
- +# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
- +# dependency, and given that the user is not expected to run this macro,
- +# just rely on AC_PROG_CC.
- +AC_DEFUN([_AM_DEPENDENCIES],
- +[AC_REQUIRE([AM_SET_DEPDIR])dnl
- +AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
- +AC_REQUIRE([AM_MAKE_INCLUDE])dnl
- +AC_REQUIRE([AM_DEP_TRACK])dnl
- +
- +ifelse([$1], CC, [depcc="$CC" am_compiler_list=],
- + [$1], CXX, [depcc="$CXX" am_compiler_list=],
- + [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
- + [$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'],
- + [depcc="$$1" am_compiler_list=])
- +
- +AC_CACHE_CHECK([dependency style of $depcc],
- + [am_cv_$1_dependencies_compiler_type],
- +[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
- + # We make a subdir and do the tests there. Otherwise we can end up
- + # making bogus files that we don't know about and never remove. For
- + # instance it was reported that on HP-UX the gcc test will end up
- + # making a dummy file named `D' -- because `-MD' means `put the output
- + # in D'.
- + mkdir conftest.dir
- + # Copy depcomp to subdir because otherwise we won't find it if we're
- + # using a relative directory.
- + cp "$am_depcomp" conftest.dir
- + cd conftest.dir
- + # We will build objects and dependencies in a subdirectory because
- + # it helps to detect inapplicable dependency modes. For instance
- + # both Tru64's cc and ICC support -MD to output dependencies as a
- + # side effect of compilation, but ICC will put the dependencies in
- + # the current directory while Tru64 will put them in the object
- + # directory.
- + mkdir sub
- +
- + am_cv_$1_dependencies_compiler_type=none
- + if test "$am_compiler_list" = ""; then
- + am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
- + fi
- + for depmode in $am_compiler_list; do
- + # Setup a source with many dependencies, because some compilers
- + # like to wrap large dependency lists on column 80 (with \), and
- + # we should not choose a depcomp mode which is confused by this.
- + #
- + # We need to recreate these files for each test, as the compiler may
- + # overwrite some of them when testing with obscure command lines.
- + # This happens at least with the AIX C compiler.
- + : > sub/conftest.c
- + for i in 1 2 3 4 5 6; do
- + echo '#include "conftst'$i'.h"' >> sub/conftest.c
- + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with
- + # Solaris 8's {/usr,}/bin/sh.
- + touch sub/conftst$i.h
- + done
- + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
- +
- + case $depmode in
- + nosideeffect)
- + # after this tag, mechanisms are not by side-effect, so they'll
- + # only be used when explicitly requested
- + if test "x$enable_dependency_tracking" = xyes; then
- + continue
- + else
- + break
- + fi
- + ;;
- + none) break ;;
- + esac
- + # We check with `-c' and `-o' for the sake of the "dashmstdout"
- + # mode. It turns out that the SunPro C++ compiler does not properly
- + # handle `-M -o', and we need to detect this.
- + if depmode=$depmode \
- + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \
- + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
- + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \
- + >/dev/null 2>conftest.err &&
- + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
- + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 &&
- + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then
- + # icc doesn't choke on unknown options, it will just issue warnings
- + # or remarks (even with -Werror). So we grep stderr for any message
- + # that says an option was ignored or not supported.
- + # When given -MP, icc 7.0 and 7.1 complain thusly:
- + # icc: Command line warning: ignoring option '-M'; no argument required
- + # The diagnosis changed in icc 8.0:
- + # icc: Command line remark: option '-MP' not supported
- + if (grep 'ignoring option' conftest.err ||
- + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
- + am_cv_$1_dependencies_compiler_type=$depmode
- + break
- + fi
- + fi
- + done
- +
- + cd ..
- + rm -rf conftest.dir
- +else
- + am_cv_$1_dependencies_compiler_type=none
- +fi
- +])
- +AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
- +AM_CONDITIONAL([am__fastdep$1], [
- + test "x$enable_dependency_tracking" != xno \
- + && test "$am_cv_$1_dependencies_compiler_type" = gcc3])
- +])
- +
- +
- +# AM_SET_DEPDIR
- +# -------------
- +# Choose a directory name for dependency files.
- +# This macro is AC_REQUIREd in _AM_DEPENDENCIES
- +AC_DEFUN([AM_SET_DEPDIR],
- +[AC_REQUIRE([AM_SET_LEADING_DOT])dnl
- +AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl
- +])
- +
- +
- +# AM_DEP_TRACK
- +# ------------
- +AC_DEFUN([AM_DEP_TRACK],
- +[AC_ARG_ENABLE(dependency-tracking,
- +[ --disable-dependency-tracking speeds up one-time build
- + --enable-dependency-tracking do not reject slow dependency extractors])
- +if test "x$enable_dependency_tracking" != xno; then
- + am_depcomp="$ac_aux_dir/depcomp"
- + AMDEPBACKSLASH='\'
- +fi
- +AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
- +AC_SUBST([AMDEPBACKSLASH])
- +])
- +
- +# Generate code to set up dependency tracking. -*- Autoconf -*-
- +
- +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004 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.
- +
- +#serial 2
- +
- +# _AM_OUTPUT_DEPENDENCY_COMMANDS
- +# ------------------------------
- +AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
- +[for mf in $CONFIG_FILES; do
- + # Strip MF so we end up with the name of the file.
- + mf=`echo "$mf" | sed -e 's/:.*$//'`
- + # Check whether this is an Automake generated Makefile or not.
- + # We used to match only the files named `Makefile.in', but
- + # some people rename them; so instead we look at the file content.
- + # Grep'ing the first line is not enough: some people post-process
- + # each Makefile.in and add a new line on top of each file to say so.
- + # So let's grep whole file.
- + if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then
- + dirpart=`AS_DIRNAME("$mf")`
- + else
- + continue
- + fi
- + grep '^DEP_FILES *= *[[^ @%:@]]' < "$mf" > /dev/null || continue
- + # Extract the definition of DEP_FILES from the Makefile without
- + # running `make'.
- + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
- + test -z "$DEPDIR" && continue
- + # When using ansi2knr, U may be empty or an underscore; expand it
- + U=`sed -n 's/^U = //p' < "$mf"`
- + test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR"
- + # We invoke sed twice because it is the simplest approach to
- + # changing $(DEPDIR) to its actual value in the expansion.
- + for file in `sed -n '
- + /^DEP_FILES = .*\\\\$/ {
- + s/^DEP_FILES = //
- + :loop
- + s/\\\\$//
- + p
- + n
- + /\\\\$/ b loop
- + p
- + }
- + /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \
- + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
- + # Make sure the directory exists.
- + test -f "$dirpart/$file" && continue
- + fdir=`AS_DIRNAME(["$file"])`
- + AS_MKDIR_P([$dirpart/$fdir])
- + # echo "creating $dirpart/$file"
- + echo '# dummy' > "$dirpart/$file"
- + done
- +done
- +])# _AM_OUTPUT_DEPENDENCY_COMMANDS
- +
- +
- +# AM_OUTPUT_DEPENDENCY_COMMANDS
- +# -----------------------------
- +# This macro should only be invoked once -- use via AC_REQUIRE.
- +#
- +# This code is only required when automatic dependency tracking
- +# is enabled. FIXME. This creates each `.P' file that we will
- +# need in order to bootstrap the dependency handling code.
- +AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
- +[AC_CONFIG_COMMANDS([depfiles],
- + [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
- + [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
- +])
- +
- +# Do all the work for Automake. -*- Autoconf -*-
- +
- +# This macro actually does too much some checks are only needed if
- +# your package does certain things. But this isn't really a big deal.
- +
- +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003
- +# 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.
- +
- +# serial 11
- +
- +# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
- +# AM_INIT_AUTOMAKE([OPTIONS])
- +# -----------------------------------------------
- +# The call with PACKAGE and VERSION arguments is the old style
- +# call (pre autoconf-2.50), which is being phased out. PACKAGE
- +# and VERSION should now be passed to AC_INIT and removed from
- +# the call to AM_INIT_AUTOMAKE.
- +# We support both call styles for the transition. After
- +# the next Automake release, Autoconf can make the AC_INIT
- +# arguments mandatory, and then we can depend on a new Autoconf
- +# release and drop the old call support.
- +AC_DEFUN([AM_INIT_AUTOMAKE],
- +[AC_PREREQ([2.58])dnl
- +dnl Autoconf wants to disallow AM_ names. We explicitly allow
- +dnl the ones we care about.
- +m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
- +AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
- +AC_REQUIRE([AC_PROG_INSTALL])dnl
- +# test to see if srcdir already configured
- +if test "`cd $srcdir && pwd`" != "`pwd`" &&
- + test -f $srcdir/config.status; then
- + AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
- +fi
- +
- +# test whether we have cygpath
- +if test -z "$CYGPATH_W"; then
- + if (cygpath --version) >/dev/null 2>/dev/null; then
- + CYGPATH_W='cygpath -w'
- + else
- + CYGPATH_W=echo
- + fi
- +fi
- +AC_SUBST([CYGPATH_W])
- +
- +# Define the identity of the package.
- +dnl Distinguish between old-style and new-style calls.
- +m4_ifval([$2],
- +[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
- + AC_SUBST([PACKAGE], [$1])dnl
- + AC_SUBST([VERSION], [$2])],
- +[_AM_SET_OPTIONS([$1])dnl
- + AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl
- + AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl
- +
- +_AM_IF_OPTION([no-define],,
- +[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
- + AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl
- +
- +# Some tools Automake needs.
- +AC_REQUIRE([AM_SANITY_CHECK])dnl
- +AC_REQUIRE([AC_ARG_PROGRAM])dnl
- +AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version})
- +AM_MISSING_PROG(AUTOCONF, autoconf)
- +AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version})
- +AM_MISSING_PROG(AUTOHEADER, autoheader)
- +AM_MISSING_PROG(MAKEINFO, makeinfo)
- +AM_MISSING_PROG(AMTAR, tar)
- +AM_PROG_INSTALL_SH
- +AM_PROG_INSTALL_STRIP
- +AC_REQUIRE([AM_PROG_MKDIR_P])dnl
- +# We need awk for the "check" target. The system "awk" is bad on
- +# some platforms.
- +AC_REQUIRE([AC_PROG_AWK])dnl
- +AC_REQUIRE([AC_PROG_MAKE_SET])dnl
- +AC_REQUIRE([AM_SET_LEADING_DOT])dnl
- +
- +_AM_IF_OPTION([no-dependencies],,
- +[AC_PROVIDE_IFELSE([AC_PROG_CC],
- + [_AM_DEPENDENCIES(CC)],
- + [define([AC_PROG_CC],
- + defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl
- +AC_PROVIDE_IFELSE([AC_PROG_CXX],
- + [_AM_DEPENDENCIES(CXX)],
- + [define([AC_PROG_CXX],
- + defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl
- +])
- +])
- +
- +
- +# When config.status generates a header, we must update the stamp-h file.
- +# This file resides in the same directory as the config header
- +# that is generated. The stamp files are numbered to have different names.
- +
- +# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the
- +# loop where config.status creates the headers, so we can generate
- +# our stamp files there.
- +AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK],
- +[# Compute $1's index in $config_headers.
- +_am_stamp_count=1
- +for _am_header in $config_headers :; do
- + case $_am_header in
- + $1 | $1:* )
- + break ;;
- + * )
- + _am_stamp_count=`expr $_am_stamp_count + 1` ;;
- + esac
- +done
- +echo "timestamp for $1" >`AS_DIRNAME([$1])`/stamp-h[]$_am_stamp_count])
- +
- +# AM_PROG_INSTALL_SH
- +# ------------------
- +# Define $install_sh.
- +
- +# Copyright (C) 2001, 2003 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.
- +
- +AC_DEFUN([AM_PROG_INSTALL_SH],
- +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
- +install_sh=${install_sh-"$am_aux_dir/install-sh"}
- +AC_SUBST(install_sh)])
- +
- +# -*- Autoconf -*-
- +# Copyright (C) 2003 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.
- +
- +# serial 1
- +
- +# Check whether the underlying file-system supports filenames
- +# with a leading dot. For instance MS-DOS doesn't.
- +AC_DEFUN([AM_SET_LEADING_DOT],
- +[rm -rf .tst 2>/dev/null
- +mkdir .tst 2>/dev/null
- +if test -d .tst; then
- + am__leading_dot=.
- +else
- + am__leading_dot=_
- +fi
- +rmdir .tst 2>/dev/null
- +AC_SUBST([am__leading_dot])])
- +
- +# Check to see how 'make' treats includes. -*- Autoconf -*-
- +
- +# Copyright (C) 2001, 2002, 2003 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.
- +
- +# serial 2
- +
- +# AM_MAKE_INCLUDE()
- +# -----------------
- +# Check to see how make treats includes.
- +AC_DEFUN([AM_MAKE_INCLUDE],
- +[am_make=${MAKE-make}
- +cat > confinc << 'END'
- +am__doit:
- + @echo done
- +.PHONY: am__doit
- +END
- +# If we don't find an include directive, just comment out the code.
- +AC_MSG_CHECKING([for style of include used by $am_make])
- +am__include="#"
- +am__quote=
- +_am_result=none
- +# First try GNU make style include.
- +echo "include confinc" > confmf
- +# We grep out `Entering directory' and `Leaving directory'
- +# messages which can occur if `w' ends up in MAKEFLAGS.
- +# In particular we don't look at `^make:' because GNU make might
- +# be invoked under some other name (usually "gmake"), in which
- +# case it prints its new name instead of `make'.
- +if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then
- + am__include=include
- + am__quote=
- + _am_result=GNU
- +fi
- +# Now try BSD make style include.
- +if test "$am__include" = "#"; then
- + echo '.include "confinc"' > confmf
- + if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then
- + am__include=.include
- + am__quote="\""
- + _am_result=BSD
- + fi
- +fi
- +AC_SUBST([am__include])
- +AC_SUBST([am__quote])
- +AC_MSG_RESULT([$_am_result])
- +rm -f confinc confmf
- +])
- +
- +# -*- Autoconf -*-
- +
- +
- +# Copyright (C) 1997, 1999, 2000, 2001, 2003 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.
- +
- +# serial 3
- +
- +# AM_MISSING_PROG(NAME, PROGRAM)
- +# ------------------------------
- +AC_DEFUN([AM_MISSING_PROG],
- +[AC_REQUIRE([AM_MISSING_HAS_RUN])
- +$1=${$1-"${am_missing_run}$2"}
- +AC_SUBST($1)])
- +
- +
- +# AM_MISSING_HAS_RUN
- +# ------------------
- +# Define MISSING if not defined so far and test if it supports --run.
- +# If it does, set am_missing_run to use it, otherwise, to nothing.
- +AC_DEFUN([AM_MISSING_HAS_RUN],
- +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
- +test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing"
- +# Use eval to expand $SHELL
- +if eval "$MISSING --run true"; then
- + am_missing_run="$MISSING --run "
- +else
- + am_missing_run=
- + AC_MSG_WARN([`missing' script is too old or missing])
- +fi
- +])
- +
- +# AM_PROG_MKDIR_P
- +# ---------------
- +# Check whether `mkdir -p' is supported, fallback to mkinstalldirs otherwise.
- +
- +# Copyright (C) 2003, 2004 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.
- +
- +# Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories
- +# created by `make install' are always world readable, even if the
- +# installer happens to have an overly restrictive umask (e.g. 077).
- +# This was a mistake. There are at least two reasons why we must not
- +# use `-m 0755':
- +# - it causes special bits like SGID to be ignored,
- +# - it may be too restrictive (some setups expect 775 directories).
- +#
- +# Do not use -m 0755 and let people choose whatever they expect by
- +# setting umask.
- +#
- +# We cannot accept any implementation of `mkdir' that recognizes `-p'.
- +# Some implementations (such as Solaris 8's) are not thread-safe: if a
- +# parallel make tries to run `mkdir -p a/b' and `mkdir -p a/c'
- +# concurrently, both version can detect that a/ is missing, but only
- +# one can create it and the other will error out. Consequently we
- +# restrict ourselves to GNU make (using the --version option ensures
- +# this.)
- +AC_DEFUN([AM_PROG_MKDIR_P],
- +[if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then
- + # Keeping the `.' argument allows $(mkdir_p) to be used without
- + # argument. Indeed, we sometimes output rules like
- + # $(mkdir_p) $(somedir)
- + # where $(somedir) is conditionally defined.
- + # (`test -n '$(somedir)' && $(mkdir_p) $(somedir)' is a more
- + # expensive solution, as it forces Make to start a sub-shell.)
- + mkdir_p='mkdir -p -- .'
- +else
- + # On NextStep and OpenStep, the `mkdir' command does not
- + # recognize any option. It will interpret all options as
- + # directories to create, and then abort because `.' already
- + # exists.
- + for d in ./-p ./--version;
- + do
- + test -d $d && rmdir $d
- + done
- + # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists.
- + if test -f "$ac_aux_dir/mkinstalldirs"; then
- + mkdir_p='$(mkinstalldirs)'
- + else
- + mkdir_p='$(install_sh) -d'
- + fi
- +fi
- +AC_SUBST([mkdir_p])])
- +
- +# Helper functions for option handling. -*- Autoconf -*-
- +
- +# Copyright (C) 2001, 2002, 2003 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.
- +
- +# serial 2
- +
- +# _AM_MANGLE_OPTION(NAME)
- +# -----------------------
- +AC_DEFUN([_AM_MANGLE_OPTION],
- +[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
- +
- +# _AM_SET_OPTION(NAME)
- +# ------------------------------
- +# Set option NAME. Presently that only means defining a flag for this option.
- +AC_DEFUN([_AM_SET_OPTION],
- +[m4_define(_AM_MANGLE_OPTION([$1]), 1)])
- +
- +# _AM_SET_OPTIONS(OPTIONS)
- +# ----------------------------------
- +# OPTIONS is a space-separated list of Automake options.
- +AC_DEFUN([_AM_SET_OPTIONS],
- +[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
- +
- +# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
- +# -------------------------------------------
- +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
- +AC_DEFUN([_AM_IF_OPTION],
- +[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
- +
- +#
- +# Check to make sure that the build environment is sane.
- +#
- +
- +# Copyright (C) 1996, 1997, 2000, 2001, 2003 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.
- +
- +# serial 3
- +
- +# AM_SANITY_CHECK
- +# ---------------
- +AC_DEFUN([AM_SANITY_CHECK],
- +[AC_MSG_CHECKING([whether build environment is sane])
- +# Just in case
- +sleep 1
- +echo timestamp > conftest.file
- +# Do `set' in a subshell so we don't clobber the current shell's
- +# arguments. Must try -L first in case configure is actually a
- +# symlink; some systems play weird games with the mod time of symlinks
- +# (eg FreeBSD returns the mod time of the symlink's containing
- +# directory).
- +if (
- + set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null`
- + if test "$[*]" = "X"; then
- + # -L didn't work.
- + set X `ls -t $srcdir/configure conftest.file`
- + fi
- + rm -f conftest.file
- + if test "$[*]" != "X $srcdir/configure conftest.file" \
- + && test "$[*]" != "X conftest.file $srcdir/configure"; then
- +
- + # If neither matched, then we have a broken ls. This can happen
- + # if, for instance, CONFIG_SHELL is bash and it inherits a
- + # broken ls alias from the environment. This has actually
- + # happened. Such a system could not be considered "sane".
- + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
- +alias in your environment])
- + fi
- +
- + test "$[2]" = conftest.file
- + )
- +then
- + # Ok.
- + :
- +else
- + AC_MSG_ERROR([newly created file is older than distributed files!
- +Check your system clock])
- +fi
- +AC_MSG_RESULT(yes)])
- +
- +# AM_PROG_INSTALL_STRIP
- +
- +# Copyright (C) 2001, 2003 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.
- +
- +# One issue with vendor `install' (even GNU) is that you can't
- +# specify the program used to strip binaries. This is especially
- +# annoying in cross-compiling environments, where the build's strip
- +# is unlikely to handle the host's binaries.
- +# Fortunately install-sh will honor a STRIPPROG variable, so we
- +# always use install-sh in `make install-strip', and initialize
- +# STRIPPROG with the value of the STRIP variable (set by the user).
- +AC_DEFUN([AM_PROG_INSTALL_STRIP],
- +[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
- +# Installed binaries are usually stripped using `strip' when the user
- +# run `make install-strip'. However `strip' might not be the right
- +# tool to use in cross-compilation environments, therefore Automake
- +# will honor the `STRIP' environment variable to overrule this program.
- +dnl Don't test for $cross_compiling = yes, because it might be `maybe'.
- +if test "$cross_compiling" != no; then
- + AC_CHECK_TOOL([STRIP], [strip], :)
- +fi
- +INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s"
- +AC_SUBST([INSTALL_STRIP_PROGRAM])])
- +
- diff --exclude CVS -urN genext2fs-1.3.orig/autogen.sh genext2fs/autogen.sh
- --- genext2fs-1.3.orig/autogen.sh 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/autogen.sh 2004-11-21 23:24:52.000000000 -0700
- @@ -0,0 +1,22 @@
- +#!/bin/sh
- +
- +die() {
- + echo "*** $0 failed :("
- + exit 1
- +}
- +
- +./clean.sh
- +
- +automake_flags="-c -a"
- +for p in aclocal autoconf automake ; do
- + flags=${p}_flags
- + if ! ${p} ${!flags} ; then
- + echo "*** ${p} failed :("
- + exit 1
- + fi
- +done
- +
- +echo
- +echo "Now just run:"
- +echo "./configure"
- +echo "make"
- diff --exclude CVS -urN genext2fs-1.3.orig/clean.sh genext2fs/clean.sh
- --- genext2fs-1.3.orig/clean.sh 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/clean.sh 2004-11-21 23:24:52.000000000 -0700
- @@ -0,0 +1,13 @@
- +#!/bin/bash
- +
- +for f in \
- + `find . -name Makefile.in -o -name Makefile` \
- + `find . -name .libs -o -name .deps` \
- + `find . -name '*.o' -o -name '*.la' -o -name '*.lo' -o -name '*.loT'` \
- + aclocal.m4* autom4te.cache \
- + configure config.* \
- + depcomp install-sh ltmain.sh missing mkinstalldirs libtool \
- + genext2fs
- +do
- + rm -rf $f
- +done
- diff --exclude CVS -urN genext2fs-1.3.orig/configure genext2fs/configure
- --- genext2fs-1.3.orig/configure 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/configure 2004-12-27 13:03:46.000000000 -0700
- @@ -0,0 +1,4034 @@
- +#! /bin/sh
- +# Guess values for system-dependent variables and create Makefiles.
- +# Generated by GNU Autoconf 2.59.
- +#
- +# Copyright (C) 2003 Free Software Foundation, Inc.
- +# This configure script is free software; the Free Software Foundation
- +# gives unlimited permission to copy, distribute and modify it.
- +## --------------------- ##
- +## M4sh Initialization. ##
- +## --------------------- ##
- +
- +# Be Bourne compatible
- +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
- + emulate sh
- + NULLCMD=:
- + # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which
- + # is contrary to our usage. Disable this feature.
- + alias -g '${1+"$@"}'='"$@"'
- +elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then
- + set -o posix
- +fi
- +DUALCASE=1; export DUALCASE # for MKS sh
- +
- +# Support unset when possible.
- +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
- + as_unset=unset
- +else
- + as_unset=false
- +fi
- +
- +
- +# Work around bugs in pre-3.0 UWIN ksh.
- +$as_unset ENV MAIL MAILPATH
- +PS1='$ '
- +PS2='> '
- +PS4='+ '
- +
- +# NLS nuisances.
- +for as_var in \
- + LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \
- + LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \
- + LC_TELEPHONE LC_TIME
- +do
- + if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then
- + eval $as_var=C; export $as_var
- + else
- + $as_unset $as_var
- + fi
- +done
- +
- +# Required to use basename.
- +if expr a : '\(a\)' >/dev/null 2>&1; then
- + as_expr=expr
- +else
- + as_expr=false
- +fi
- +
- +if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then
- + as_basename=basename
- +else
- + as_basename=false
- +fi
- +
- +
- +# Name of the executable.
- +as_me=`$as_basename "$0" ||
- +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \
- + X"$0" : 'X\(//\)$' \| \
- + X"$0" : 'X\(/\)$' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X/"$0" |
- + sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; }
- + /^X\/\(\/\/\)$/{ s//\1/; q; }
- + /^X\/\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- +
- +
- +# PATH needs CR, and LINENO needs CR and PATH.
- +# Avoid depending upon Character Ranges.
- +as_cr_letters='abcdefghijklmnopqrstuvwxyz'
- +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ'
- +as_cr_Letters=$as_cr_letters$as_cr_LETTERS
- +as_cr_digits='0123456789'
- +as_cr_alnum=$as_cr_Letters$as_cr_digits
- +
- +# The user is always right.
- +if test "${PATH_SEPARATOR+set}" != set; then
- + echo "#! /bin/sh" >conf$$.sh
- + echo "exit 0" >>conf$$.sh
- + chmod +x conf$$.sh
- + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then
- + PATH_SEPARATOR=';'
- + else
- + PATH_SEPARATOR=:
- + fi
- + rm -f conf$$.sh
- +fi
- +
- +
- + as_lineno_1=$LINENO
- + as_lineno_2=$LINENO
- + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null`
- + test "x$as_lineno_1" != "x$as_lineno_2" &&
- + test "x$as_lineno_3" = "x$as_lineno_2" || {
- + # Find who we are. Look in the path if we contain no path at all
- + # relative or not.
- + case $0 in
- + *[\\/]* ) as_myself=$0 ;;
- + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break
- +done
- +
- + ;;
- + esac
- + # We did not find ourselves, most probably we were run as `sh COMMAND'
- + # in which case we are not to be found in the path.
- + if test "x$as_myself" = x; then
- + as_myself=$0
- + fi
- + if test ! -f "$as_myself"; then
- + { echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2
- + { (exit 1); exit 1; }; }
- + fi
- + case $CONFIG_SHELL in
- + '')
- + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for as_base in sh bash ksh sh5; do
- + case $as_dir in
- + /*)
- + if ("$as_dir/$as_base" -c '
- + as_lineno_1=$LINENO
- + as_lineno_2=$LINENO
- + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null`
- + test "x$as_lineno_1" != "x$as_lineno_2" &&
- + test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then
- + $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; }
- + $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; }
- + CONFIG_SHELL=$as_dir/$as_base
- + export CONFIG_SHELL
- + exec "$CONFIG_SHELL" "$0" ${1+"$@"}
- + fi;;
- + esac
- + done
- +done
- +;;
- + esac
- +
- + # Create $as_me.lineno as a copy of $as_myself, but with $LINENO
- + # uniformly replaced by the line number. The first 'sed' inserts a
- + # line-number line before each line; the second 'sed' does the real
- + # work. The second script uses 'N' to pair each line-number line
- + # with the numbered line, and appends trailing '-' during
- + # substitution so that $LINENO is not a special case at line end.
- + # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the
- + # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-)
- + sed '=' <$as_myself |
- + sed '
- + N
- + s,$,-,
- + : loop
- + s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3,
- + t loop
- + s,-$,,
- + s,^['$as_cr_digits']*\n,,
- + ' >$as_me.lineno &&
- + chmod +x $as_me.lineno ||
- + { echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2
- + { (exit 1); exit 1; }; }
- +
- + # Don't try to exec as it changes $[0], causing all sort of problems
- + # (the dirname of $[0] is not the place where we might find the
- + # original and so on. Autoconf is especially sensible to this).
- + . ./$as_me.lineno
- + # Exit status is that of the last command.
- + exit
- +}
- +
- +
- +case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in
- + *c*,-n*) ECHO_N= ECHO_C='
- +' ECHO_T=' ' ;;
- + *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;;
- + *) ECHO_N= ECHO_C='\c' ECHO_T= ;;
- +esac
- +
- +if expr a : '\(a\)' >/dev/null 2>&1; then
- + as_expr=expr
- +else
- + as_expr=false
- +fi
- +
- +rm -f conf$$ conf$$.exe conf$$.file
- +echo >conf$$.file
- +if ln -s conf$$.file conf$$ 2>/dev/null; then
- + # We could just check for DJGPP; but this test a) works b) is more generic
- + # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04).
- + if test -f conf$$.exe; then
- + # Don't use ln at all; we don't have any links
- + as_ln_s='cp -p'
- + else
- + as_ln_s='ln -s'
- + fi
- +elif ln conf$$.file conf$$ 2>/dev/null; then
- + as_ln_s=ln
- +else
- + as_ln_s='cp -p'
- +fi
- +rm -f conf$$ conf$$.exe conf$$.file
- +
- +if mkdir -p . 2>/dev/null; then
- + as_mkdir_p=:
- +else
- + test -d ./-p && rmdir ./-p
- + as_mkdir_p=false
- +fi
- +
- +as_executable_p="test -f"
- +
- +# Sed expression to map a string onto a valid CPP name.
- +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'"
- +
- +# Sed expression to map a string onto a valid variable name.
- +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'"
- +
- +
- +# IFS
- +# We need space, tab and new line, in precisely that order.
- +as_nl='
- +'
- +IFS=" $as_nl"
- +
- +# CDPATH.
- +$as_unset CDPATH
- +
- +
- +# Name of the host.
- +# hostname on some systems (SVR3.2, Linux) returns a bogus exit status,
- +# so uname gets run too.
- +ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q`
- +
- +exec 6>&1
- +
- +#
- +# Initializations.
- +#
- +ac_default_prefix=/usr/local
- +ac_config_libobj_dir=.
- +cross_compiling=no
- +subdirs=
- +MFLAGS=
- +MAKEFLAGS=
- +SHELL=${CONFIG_SHELL-/bin/sh}
- +
- +# Maximum number of lines to put in a shell here document.
- +# This variable seems obsolete. It should probably be removed, and
- +# only ac_max_sed_lines should be used.
- +: ${ac_max_here_lines=38}
- +
- +# Identity of this package.
- +PACKAGE_NAME=
- +PACKAGE_TARNAME=
- +PACKAGE_VERSION=
- +PACKAGE_STRING=
- +PACKAGE_BUGREPORT=
- +
- +ac_unique_file="genext2fs.c"
- +ac_subst_vars='SHELL PATH_SEPARATOR PACKAGE_NAME PACKAGE_TARNAME PACKAGE_VERSION PACKAGE_STRING PACKAGE_BUGREPORT exec_prefix prefix program_transform_name bindir sbindir libexecdir datadir sysconfdir sharedstatedir localstatedir libdir includedir oldincludedir infodir mandir build_alias host_alias target_alias DEFS ECHO_C ECHO_N ECHO_T LIBS INSTALL_PROGRAM INSTALL_SCRIPT INSTALL_DATA CYGPATH_W PACKAGE VERSION ACLOCAL AUTOCONF AUTOMAKE AUTOHEADER MAKEINFO AMTAR install_sh STRIP ac_ct_STRIP INSTALL_STRIP_PROGRAM mkdir_p AWK SET_MAKE am__leading_dot CC CFLAGS LDFLAGS CPPFLAGS ac_ct_CC EXEEXT OBJEXT DEPDIR am__include am__quote AMDEP_TRUE AMDEP_FALSE AMDEPBACKSLASH CCDEPMODE am__fastdepCC_TRUE am__fastdepCC_FALSE LIBOBJS LTLIBOBJS'
- +ac_subst_files=''
- +
- +# Initialize some variables set by options.
- +ac_init_help=
- +ac_init_version=false
- +# The variables have the same names as the options, with
- +# dashes changed to underlines.
- +cache_file=/dev/null
- +exec_prefix=NONE
- +no_create=
- +no_recursion=
- +prefix=NONE
- +program_prefix=NONE
- +program_suffix=NONE
- +program_transform_name=s,x,x,
- +silent=
- +site=
- +srcdir=
- +verbose=
- +x_includes=NONE
- +x_libraries=NONE
- +
- +# Installation directory options.
- +# These are left unexpanded so users can "make install exec_prefix=/foo"
- +# and all the variables that are supposed to be based on exec_prefix
- +# by default will actually change.
- +# Use braces instead of parens because sh, perl, etc. also accept them.
- +bindir='${exec_prefix}/bin'
- +sbindir='${exec_prefix}/sbin'
- +libexecdir='${exec_prefix}/libexec'
- +datadir='${prefix}/share'
- +sysconfdir='${prefix}/etc'
- +sharedstatedir='${prefix}/com'
- +localstatedir='${prefix}/var'
- +libdir='${exec_prefix}/lib'
- +includedir='${prefix}/include'
- +oldincludedir='/usr/include'
- +infodir='${prefix}/info'
- +mandir='${prefix}/man'
- +
- +ac_prev=
- +for ac_option
- +do
- + # If the previous option needs an argument, assign it.
- + if test -n "$ac_prev"; then
- + eval "$ac_prev=\$ac_option"
- + ac_prev=
- + continue
- + fi
- +
- + ac_optarg=`expr "x$ac_option" : 'x[^=]*=\(.*\)'`
- +
- + # Accept the important Cygnus configure options, so we can diagnose typos.
- +
- + case $ac_option in
- +
- + -bindir | --bindir | --bindi | --bind | --bin | --bi)
- + ac_prev=bindir ;;
- + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*)
- + bindir=$ac_optarg ;;
- +
- + -build | --build | --buil | --bui | --bu)
- + ac_prev=build_alias ;;
- + -build=* | --build=* | --buil=* | --bui=* | --bu=*)
- + build_alias=$ac_optarg ;;
- +
- + -cache-file | --cache-file | --cache-fil | --cache-fi \
- + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c)
- + ac_prev=cache_file ;;
- + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \
- + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*)
- + cache_file=$ac_optarg ;;
- +
- + --config-cache | -C)
- + cache_file=config.cache ;;
- +
- + -datadir | --datadir | --datadi | --datad | --data | --dat | --da)
- + ac_prev=datadir ;;
- + -datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* \
- + | --da=*)
- + datadir=$ac_optarg ;;
- +
- + -disable-* | --disable-*)
- + ac_feature=`expr "x$ac_option" : 'x-*disable-\(.*\)'`
- + # Reject names that are not valid shell variable names.
- + expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null &&
- + { echo "$as_me: error: invalid feature name: $ac_feature" >&2
- + { (exit 1); exit 1; }; }
- + ac_feature=`echo $ac_feature | sed 's/-/_/g'`
- + eval "enable_$ac_feature=no" ;;
- +
- + -enable-* | --enable-*)
- + ac_feature=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'`
- + # Reject names that are not valid shell variable names.
- + expr "x$ac_feature" : ".*[^-_$as_cr_alnum]" >/dev/null &&
- + { echo "$as_me: error: invalid feature name: $ac_feature" >&2
- + { (exit 1); exit 1; }; }
- + ac_feature=`echo $ac_feature | sed 's/-/_/g'`
- + case $ac_option in
- + *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;;
- + *) ac_optarg=yes ;;
- + esac
- + eval "enable_$ac_feature='$ac_optarg'" ;;
- +
- + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \
- + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \
- + | --exec | --exe | --ex)
- + ac_prev=exec_prefix ;;
- + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \
- + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \
- + | --exec=* | --exe=* | --ex=*)
- + exec_prefix=$ac_optarg ;;
- +
- + -gas | --gas | --ga | --g)
- + # Obsolete; use --with-gas.
- + with_gas=yes ;;
- +
- + -help | --help | --hel | --he | -h)
- + ac_init_help=long ;;
- + -help=r* | --help=r* | --hel=r* | --he=r* | -hr*)
- + ac_init_help=recursive ;;
- + -help=s* | --help=s* | --hel=s* | --he=s* | -hs*)
- + ac_init_help=short ;;
- +
- + -host | --host | --hos | --ho)
- + ac_prev=host_alias ;;
- + -host=* | --host=* | --hos=* | --ho=*)
- + host_alias=$ac_optarg ;;
- +
- + -includedir | --includedir | --includedi | --included | --include \
- + | --includ | --inclu | --incl | --inc)
- + ac_prev=includedir ;;
- + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \
- + | --includ=* | --inclu=* | --incl=* | --inc=*)
- + includedir=$ac_optarg ;;
- +
- + -infodir | --infodir | --infodi | --infod | --info | --inf)
- + ac_prev=infodir ;;
- + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*)
- + infodir=$ac_optarg ;;
- +
- + -libdir | --libdir | --libdi | --libd)
- + ac_prev=libdir ;;
- + -libdir=* | --libdir=* | --libdi=* | --libd=*)
- + libdir=$ac_optarg ;;
- +
- + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \
- + | --libexe | --libex | --libe)
- + ac_prev=libexecdir ;;
- + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \
- + | --libexe=* | --libex=* | --libe=*)
- + libexecdir=$ac_optarg ;;
- +
- + -localstatedir | --localstatedir | --localstatedi | --localstated \
- + | --localstate | --localstat | --localsta | --localst \
- + | --locals | --local | --loca | --loc | --lo)
- + ac_prev=localstatedir ;;
- + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \
- + | --localstate=* | --localstat=* | --localsta=* | --localst=* \
- + | --locals=* | --local=* | --loca=* | --loc=* | --lo=*)
- + localstatedir=$ac_optarg ;;
- +
- + -mandir | --mandir | --mandi | --mand | --man | --ma | --m)
- + ac_prev=mandir ;;
- + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*)
- + mandir=$ac_optarg ;;
- +
- + -nfp | --nfp | --nf)
- + # Obsolete; use --without-fp.
- + with_fp=no ;;
- +
- + -no-create | --no-create | --no-creat | --no-crea | --no-cre \
- + | --no-cr | --no-c | -n)
- + no_create=yes ;;
- +
- + -no-recursion | --no-recursion | --no-recursio | --no-recursi \
- + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r)
- + no_recursion=yes ;;
- +
- + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \
- + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \
- + | --oldin | --oldi | --old | --ol | --o)
- + ac_prev=oldincludedir ;;
- + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \
- + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \
- + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*)
- + oldincludedir=$ac_optarg ;;
- +
- + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p)
- + ac_prev=prefix ;;
- + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*)
- + prefix=$ac_optarg ;;
- +
- + -program-prefix | --program-prefix | --program-prefi | --program-pref \
- + | --program-pre | --program-pr | --program-p)
- + ac_prev=program_prefix ;;
- + -program-prefix=* | --program-prefix=* | --program-prefi=* \
- + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*)
- + program_prefix=$ac_optarg ;;
- +
- + -program-suffix | --program-suffix | --program-suffi | --program-suff \
- + | --program-suf | --program-su | --program-s)
- + ac_prev=program_suffix ;;
- + -program-suffix=* | --program-suffix=* | --program-suffi=* \
- + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*)
- + program_suffix=$ac_optarg ;;
- +
- + -program-transform-name | --program-transform-name \
- + | --program-transform-nam | --program-transform-na \
- + | --program-transform-n | --program-transform- \
- + | --program-transform | --program-transfor \
- + | --program-transfo | --program-transf \
- + | --program-trans | --program-tran \
- + | --progr-tra | --program-tr | --program-t)
- + ac_prev=program_transform_name ;;
- + -program-transform-name=* | --program-transform-name=* \
- + | --program-transform-nam=* | --program-transform-na=* \
- + | --program-transform-n=* | --program-transform-=* \
- + | --program-transform=* | --program-transfor=* \
- + | --program-transfo=* | --program-transf=* \
- + | --program-trans=* | --program-tran=* \
- + | --progr-tra=* | --program-tr=* | --program-t=*)
- + program_transform_name=$ac_optarg ;;
- +
- + -q | -quiet | --quiet | --quie | --qui | --qu | --q \
- + | -silent | --silent | --silen | --sile | --sil)
- + silent=yes ;;
- +
- + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb)
- + ac_prev=sbindir ;;
- + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \
- + | --sbi=* | --sb=*)
- + sbindir=$ac_optarg ;;
- +
- + -sharedstatedir | --sharedstatedir | --sharedstatedi \
- + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \
- + | --sharedst | --shareds | --shared | --share | --shar \
- + | --sha | --sh)
- + ac_prev=sharedstatedir ;;
- + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \
- + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \
- + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \
- + | --sha=* | --sh=*)
- + sharedstatedir=$ac_optarg ;;
- +
- + -site | --site | --sit)
- + ac_prev=site ;;
- + -site=* | --site=* | --sit=*)
- + site=$ac_optarg ;;
- +
- + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr)
- + ac_prev=srcdir ;;
- + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*)
- + srcdir=$ac_optarg ;;
- +
- + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \
- + | --syscon | --sysco | --sysc | --sys | --sy)
- + ac_prev=sysconfdir ;;
- + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \
- + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*)
- + sysconfdir=$ac_optarg ;;
- +
- + -target | --target | --targe | --targ | --tar | --ta | --t)
- + ac_prev=target_alias ;;
- + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*)
- + target_alias=$ac_optarg ;;
- +
- + -v | -verbose | --verbose | --verbos | --verbo | --verb)
- + verbose=yes ;;
- +
- + -version | --version | --versio | --versi | --vers | -V)
- + ac_init_version=: ;;
- +
- + -with-* | --with-*)
- + ac_package=`expr "x$ac_option" : 'x-*with-\([^=]*\)'`
- + # Reject names that are not valid shell variable names.
- + expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null &&
- + { echo "$as_me: error: invalid package name: $ac_package" >&2
- + { (exit 1); exit 1; }; }
- + ac_package=`echo $ac_package| sed 's/-/_/g'`
- + case $ac_option in
- + *=*) ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`;;
- + *) ac_optarg=yes ;;
- + esac
- + eval "with_$ac_package='$ac_optarg'" ;;
- +
- + -without-* | --without-*)
- + ac_package=`expr "x$ac_option" : 'x-*without-\(.*\)'`
- + # Reject names that are not valid shell variable names.
- + expr "x$ac_package" : ".*[^-_$as_cr_alnum]" >/dev/null &&
- + { echo "$as_me: error: invalid package name: $ac_package" >&2
- + { (exit 1); exit 1; }; }
- + ac_package=`echo $ac_package | sed 's/-/_/g'`
- + eval "with_$ac_package=no" ;;
- +
- + --x)
- + # Obsolete; use --with-x.
- + with_x=yes ;;
- +
- + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \
- + | --x-incl | --x-inc | --x-in | --x-i)
- + ac_prev=x_includes ;;
- + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \
- + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*)
- + x_includes=$ac_optarg ;;
- +
- + -x-libraries | --x-libraries | --x-librarie | --x-librari \
- + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l)
- + ac_prev=x_libraries ;;
- + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \
- + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*)
- + x_libraries=$ac_optarg ;;
- +
- + -*) { echo "$as_me: error: unrecognized option: $ac_option
- +Try \`$0 --help' for more information." >&2
- + { (exit 1); exit 1; }; }
- + ;;
- +
- + *=*)
- + ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='`
- + # Reject names that are not valid shell variable names.
- + expr "x$ac_envvar" : ".*[^_$as_cr_alnum]" >/dev/null &&
- + { echo "$as_me: error: invalid variable name: $ac_envvar" >&2
- + { (exit 1); exit 1; }; }
- + ac_optarg=`echo "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"`
- + eval "$ac_envvar='$ac_optarg'"
- + export $ac_envvar ;;
- +
- + *)
- + # FIXME: should be removed in autoconf 3.0.
- + echo "$as_me: WARNING: you should use --build, --host, --target" >&2
- + expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null &&
- + echo "$as_me: WARNING: invalid host type: $ac_option" >&2
- + : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}
- + ;;
- +
- + esac
- +done
- +
- +if test -n "$ac_prev"; then
- + ac_option=--`echo $ac_prev | sed 's/_/-/g'`
- + { echo "$as_me: error: missing argument to $ac_option" >&2
- + { (exit 1); exit 1; }; }
- +fi
- +
- +# Be sure to have absolute paths.
- +for ac_var in exec_prefix prefix
- +do
- + eval ac_val=$`echo $ac_var`
- + case $ac_val in
- + [\\/$]* | ?:[\\/]* | NONE | '' ) ;;
- + *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2
- + { (exit 1); exit 1; }; };;
- + esac
- +done
- +
- +# Be sure to have absolute paths.
- +for ac_var in bindir sbindir libexecdir datadir sysconfdir sharedstatedir \
- + localstatedir libdir includedir oldincludedir infodir mandir
- +do
- + eval ac_val=$`echo $ac_var`
- + case $ac_val in
- + [\\/$]* | ?:[\\/]* ) ;;
- + *) { echo "$as_me: error: expected an absolute directory name for --$ac_var: $ac_val" >&2
- + { (exit 1); exit 1; }; };;
- + esac
- +done
- +
- +# There might be people who depend on the old broken behavior: `$host'
- +# used to hold the argument of --host etc.
- +# FIXME: To remove some day.
- +build=$build_alias
- +host=$host_alias
- +target=$target_alias
- +
- +# FIXME: To remove some day.
- +if test "x$host_alias" != x; then
- + if test "x$build_alias" = x; then
- + cross_compiling=maybe
- + echo "$as_me: WARNING: If you wanted to set the --build type, don't use --host.
- + If a cross compiler is detected then cross compile mode will be used." >&2
- + elif test "x$build_alias" != "x$host_alias"; then
- + cross_compiling=yes
- + fi
- +fi
- +
- +ac_tool_prefix=
- +test -n "$host_alias" && ac_tool_prefix=$host_alias-
- +
- +test "$silent" = yes && exec 6>/dev/null
- +
- +
- +# Find the source files, if location was not specified.
- +if test -z "$srcdir"; then
- + ac_srcdir_defaulted=yes
- + # Try the directory containing this script, then its parent.
- + ac_confdir=`(dirname "$0") 2>/dev/null ||
- +$as_expr X"$0" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$0" : 'X\(//\)[^/]' \| \
- + X"$0" : 'X\(//\)$' \| \
- + X"$0" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$0" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + srcdir=$ac_confdir
- + if test ! -r $srcdir/$ac_unique_file; then
- + srcdir=..
- + fi
- +else
- + ac_srcdir_defaulted=no
- +fi
- +if test ! -r $srcdir/$ac_unique_file; then
- + if test "$ac_srcdir_defaulted" = yes; then
- + { echo "$as_me: error: cannot find sources ($ac_unique_file) in $ac_confdir or .." >&2
- + { (exit 1); exit 1; }; }
- + else
- + { echo "$as_me: error: cannot find sources ($ac_unique_file) in $srcdir" >&2
- + { (exit 1); exit 1; }; }
- + fi
- +fi
- +(cd $srcdir && test -r ./$ac_unique_file) 2>/dev/null ||
- + { echo "$as_me: error: sources are in $srcdir, but \`cd $srcdir' does not work" >&2
- + { (exit 1); exit 1; }; }
- +srcdir=`echo "$srcdir" | sed 's%\([^\\/]\)[\\/]*$%\1%'`
- +ac_env_build_alias_set=${build_alias+set}
- +ac_env_build_alias_value=$build_alias
- +ac_cv_env_build_alias_set=${build_alias+set}
- +ac_cv_env_build_alias_value=$build_alias
- +ac_env_host_alias_set=${host_alias+set}
- +ac_env_host_alias_value=$host_alias
- +ac_cv_env_host_alias_set=${host_alias+set}
- +ac_cv_env_host_alias_value=$host_alias
- +ac_env_target_alias_set=${target_alias+set}
- +ac_env_target_alias_value=$target_alias
- +ac_cv_env_target_alias_set=${target_alias+set}
- +ac_cv_env_target_alias_value=$target_alias
- +ac_env_CC_set=${CC+set}
- +ac_env_CC_value=$CC
- +ac_cv_env_CC_set=${CC+set}
- +ac_cv_env_CC_value=$CC
- +ac_env_CFLAGS_set=${CFLAGS+set}
- +ac_env_CFLAGS_value=$CFLAGS
- +ac_cv_env_CFLAGS_set=${CFLAGS+set}
- +ac_cv_env_CFLAGS_value=$CFLAGS
- +ac_env_LDFLAGS_set=${LDFLAGS+set}
- +ac_env_LDFLAGS_value=$LDFLAGS
- +ac_cv_env_LDFLAGS_set=${LDFLAGS+set}
- +ac_cv_env_LDFLAGS_value=$LDFLAGS
- +ac_env_CPPFLAGS_set=${CPPFLAGS+set}
- +ac_env_CPPFLAGS_value=$CPPFLAGS
- +ac_cv_env_CPPFLAGS_set=${CPPFLAGS+set}
- +ac_cv_env_CPPFLAGS_value=$CPPFLAGS
- +
- +#
- +# Report the --help message.
- +#
- +if test "$ac_init_help" = "long"; then
- + # Omit some internal or obsolete options to make the list less imposing.
- + # This message is too long to be a string in the A/UX 3.1 sh.
- + cat <<_ACEOF
- +\`configure' configures this package to adapt to many kinds of systems.
- +
- +Usage: $0 [OPTION]... [VAR=VALUE]...
- +
- +To assign environment variables (e.g., CC, CFLAGS...), specify them as
- +VAR=VALUE. See below for descriptions of some of the useful variables.
- +
- +Defaults for the options are specified in brackets.
- +
- +Configuration:
- + -h, --help display this help and exit
- + --help=short display options specific to this package
- + --help=recursive display the short help of all the included packages
- + -V, --version display version information and exit
- + -q, --quiet, --silent do not print \`checking...' messages
- + --cache-file=FILE cache test results in FILE [disabled]
- + -C, --config-cache alias for \`--cache-file=config.cache'
- + -n, --no-create do not create output files
- + --srcdir=DIR find the sources in DIR [configure dir or \`..']
- +
- +_ACEOF
- +
- + cat <<_ACEOF
- +Installation directories:
- + --prefix=PREFIX install architecture-independent files in PREFIX
- + [$ac_default_prefix]
- + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX
- + [PREFIX]
- +
- +By default, \`make install' will install all the files in
- +\`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify
- +an installation prefix other than \`$ac_default_prefix' using \`--prefix',
- +for instance \`--prefix=\$HOME'.
- +
- +For better control, use the options below.
- +
- +Fine tuning of the installation directories:
- + --bindir=DIR user executables [EPREFIX/bin]
- + --sbindir=DIR system admin executables [EPREFIX/sbin]
- + --libexecdir=DIR program executables [EPREFIX/libexec]
- + --datadir=DIR read-only architecture-independent data [PREFIX/share]
- + --sysconfdir=DIR read-only single-machine data [PREFIX/etc]
- + --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
- + --localstatedir=DIR modifiable single-machine data [PREFIX/var]
- + --libdir=DIR object code libraries [EPREFIX/lib]
- + --includedir=DIR C header files [PREFIX/include]
- + --oldincludedir=DIR C header files for non-gcc [/usr/include]
- + --infodir=DIR info documentation [PREFIX/info]
- + --mandir=DIR man documentation [PREFIX/man]
- +_ACEOF
- +
- + cat <<\_ACEOF
- +
- +Program names:
- + --program-prefix=PREFIX prepend PREFIX to installed program names
- + --program-suffix=SUFFIX append SUFFIX to installed program names
- + --program-transform-name=PROGRAM run sed PROGRAM on installed program names
- +_ACEOF
- +fi
- +
- +if test -n "$ac_init_help"; then
- +
- + cat <<\_ACEOF
- +
- +Optional Features:
- + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no)
- + --enable-FEATURE[=ARG] include FEATURE [ARG=yes]
- + --disable-dependency-tracking speeds up one-time build
- + --enable-dependency-tracking do not reject slow dependency extractors
- +
- +Some influential environment variables:
- + CC C compiler command
- + CFLAGS C compiler flags
- + LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a
- + nonstandard directory <lib dir>
- + CPPFLAGS C/C++ preprocessor flags, e.g. -I<include dir> if you have
- + headers in a nonstandard directory <include dir>
- +
- +Use these variables to override the choices made by `configure' or to help
- +it to find libraries and programs with nonstandard names/locations.
- +
- +_ACEOF
- +fi
- +
- +if test "$ac_init_help" = "recursive"; then
- + # If there are subdirs, report their specific --help.
- + ac_popdir=`pwd`
- + for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue
- + test -d $ac_dir || continue
- + ac_builddir=.
- +
- +if test "$ac_dir" != .; then
- + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'`
- + # A "../" for each directory in $ac_dir_suffix.
- + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'`
- +else
- + ac_dir_suffix= ac_top_builddir=
- +fi
- +
- +case $srcdir in
- + .) # No --srcdir option. We are building in place.
- + ac_srcdir=.
- + if test -z "$ac_top_builddir"; then
- + ac_top_srcdir=.
- + else
- + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'`
- + fi ;;
- + [\\/]* | ?:[\\/]* ) # Absolute path.
- + ac_srcdir=$srcdir$ac_dir_suffix;
- + ac_top_srcdir=$srcdir ;;
- + *) # Relative path.
- + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix
- + ac_top_srcdir=$ac_top_builddir$srcdir ;;
- +esac
- +
- +# Do not use `cd foo && pwd` to compute absolute paths, because
- +# the directories may not exist.
- +case `pwd` in
- +.) ac_abs_builddir="$ac_dir";;
- +*)
- + case "$ac_dir" in
- + .) ac_abs_builddir=`pwd`;;
- + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";;
- + *) ac_abs_builddir=`pwd`/"$ac_dir";;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_builddir=${ac_top_builddir}.;;
- +*)
- + case ${ac_top_builddir}. in
- + .) ac_abs_top_builddir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;;
- + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_srcdir=$ac_srcdir;;
- +*)
- + case $ac_srcdir in
- + .) ac_abs_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;;
- + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_srcdir=$ac_top_srcdir;;
- +*)
- + case $ac_top_srcdir in
- + .) ac_abs_top_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;;
- + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;;
- + esac;;
- +esac
- +
- + cd $ac_dir
- + # Check for guested configure; otherwise get Cygnus style configure.
- + if test -f $ac_srcdir/configure.gnu; then
- + echo
- + $SHELL $ac_srcdir/configure.gnu --help=recursive
- + elif test -f $ac_srcdir/configure; then
- + echo
- + $SHELL $ac_srcdir/configure --help=recursive
- + elif test -f $ac_srcdir/configure.ac ||
- + test -f $ac_srcdir/configure.in; then
- + echo
- + $ac_configure --help
- + else
- + echo "$as_me: WARNING: no configuration information is in $ac_dir" >&2
- + fi
- + cd "$ac_popdir"
- + done
- +fi
- +
- +test -n "$ac_init_help" && exit 0
- +if $ac_init_version; then
- + cat <<\_ACEOF
- +
- +Copyright (C) 2003 Free Software Foundation, Inc.
- +This configure script is free software; the Free Software Foundation
- +gives unlimited permission to copy, distribute and modify it.
- +_ACEOF
- + exit 0
- +fi
- +exec 5>config.log
- +cat >&5 <<_ACEOF
- +This file contains any messages produced by compilers while
- +running configure, to aid debugging if configure makes a mistake.
- +
- +It was created by $as_me, which was
- +generated by GNU Autoconf 2.59. Invocation command line was
- +
- + $ $0 $@
- +
- +_ACEOF
- +{
- +cat <<_ASUNAME
- +## --------- ##
- +## Platform. ##
- +## --------- ##
- +
- +hostname = `(hostname || uname -n) 2>/dev/null | sed 1q`
- +uname -m = `(uname -m) 2>/dev/null || echo unknown`
- +uname -r = `(uname -r) 2>/dev/null || echo unknown`
- +uname -s = `(uname -s) 2>/dev/null || echo unknown`
- +uname -v = `(uname -v) 2>/dev/null || echo unknown`
- +
- +/usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown`
- +/bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown`
- +
- +/bin/arch = `(/bin/arch) 2>/dev/null || echo unknown`
- +/usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown`
- +/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown`
- +hostinfo = `(hostinfo) 2>/dev/null || echo unknown`
- +/bin/machine = `(/bin/machine) 2>/dev/null || echo unknown`
- +/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown`
- +/bin/universe = `(/bin/universe) 2>/dev/null || echo unknown`
- +
- +_ASUNAME
- +
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + echo "PATH: $as_dir"
- +done
- +
- +} >&5
- +
- +cat >&5 <<_ACEOF
- +
- +
- +## ----------- ##
- +## Core tests. ##
- +## ----------- ##
- +
- +_ACEOF
- +
- +
- +# Keep a trace of the command line.
- +# Strip out --no-create and --no-recursion so they do not pile up.
- +# Strip out --silent because we don't want to record it for future runs.
- +# Also quote any args containing shell meta-characters.
- +# Make two passes to allow for proper duplicate-argument suppression.
- +ac_configure_args=
- +ac_configure_args0=
- +ac_configure_args1=
- +ac_sep=
- +ac_must_keep_next=false
- +for ac_pass in 1 2
- +do
- + for ac_arg
- + do
- + case $ac_arg in
- + -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;;
- + -q | -quiet | --quiet | --quie | --qui | --qu | --q \
- + | -silent | --silent | --silen | --sile | --sil)
- + continue ;;
- + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*)
- + ac_arg=`echo "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;;
- + esac
- + case $ac_pass in
- + 1) ac_configure_args0="$ac_configure_args0 '$ac_arg'" ;;
- + 2)
- + ac_configure_args1="$ac_configure_args1 '$ac_arg'"
- + if test $ac_must_keep_next = true; then
- + ac_must_keep_next=false # Got value, back to normal.
- + else
- + case $ac_arg in
- + *=* | --config-cache | -C | -disable-* | --disable-* \
- + | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \
- + | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \
- + | -with-* | --with-* | -without-* | --without-* | --x)
- + case "$ac_configure_args0 " in
- + "$ac_configure_args1"*" '$ac_arg' "* ) continue ;;
- + esac
- + ;;
- + -* ) ac_must_keep_next=true ;;
- + esac
- + fi
- + ac_configure_args="$ac_configure_args$ac_sep'$ac_arg'"
- + # Get rid of the leading space.
- + ac_sep=" "
- + ;;
- + esac
- + done
- +done
- +$as_unset ac_configure_args0 || test "${ac_configure_args0+set}" != set || { ac_configure_args0=; export ac_configure_args0; }
- +$as_unset ac_configure_args1 || test "${ac_configure_args1+set}" != set || { ac_configure_args1=; export ac_configure_args1; }
- +
- +# When interrupted or exit'd, cleanup temporary files, and complete
- +# config.log. We remove comments because anyway the quotes in there
- +# would cause problems or look ugly.
- +# WARNING: Be sure not to use single quotes in there, as some shells,
- +# such as our DU 5.0 friend, will then `close' the trap.
- +trap 'exit_status=$?
- + # Save into config.log some information that might help in debugging.
- + {
- + echo
- +
- + cat <<\_ASBOX
- +## ---------------- ##
- +## Cache variables. ##
- +## ---------------- ##
- +_ASBOX
- + echo
- + # The following way of writing the cache mishandles newlines in values,
- +{
- + (set) 2>&1 |
- + case `(ac_space='"'"' '"'"'; set | grep ac_space) 2>&1` in
- + *ac_space=\ *)
- + sed -n \
- + "s/'"'"'/'"'"'\\\\'"'"''"'"'/g;
- + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='"'"'\\2'"'"'/p"
- + ;;
- + *)
- + sed -n \
- + "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p"
- + ;;
- + esac;
- +}
- + echo
- +
- + cat <<\_ASBOX
- +## ----------------- ##
- +## Output variables. ##
- +## ----------------- ##
- +_ASBOX
- + echo
- + for ac_var in $ac_subst_vars
- + do
- + eval ac_val=$`echo $ac_var`
- + echo "$ac_var='"'"'$ac_val'"'"'"
- + done | sort
- + echo
- +
- + if test -n "$ac_subst_files"; then
- + cat <<\_ASBOX
- +## ------------- ##
- +## Output files. ##
- +## ------------- ##
- +_ASBOX
- + echo
- + for ac_var in $ac_subst_files
- + do
- + eval ac_val=$`echo $ac_var`
- + echo "$ac_var='"'"'$ac_val'"'"'"
- + done | sort
- + echo
- + fi
- +
- + if test -s confdefs.h; then
- + cat <<\_ASBOX
- +## ----------- ##
- +## confdefs.h. ##
- +## ----------- ##
- +_ASBOX
- + echo
- + sed "/^$/d" confdefs.h | sort
- + echo
- + fi
- + test "$ac_signal" != 0 &&
- + echo "$as_me: caught signal $ac_signal"
- + echo "$as_me: exit $exit_status"
- + } >&5
- + rm -f core *.core &&
- + rm -rf conftest* confdefs* conf$$* $ac_clean_files &&
- + exit $exit_status
- + ' 0
- +for ac_signal in 1 2 13 15; do
- + trap 'ac_signal='$ac_signal'; { (exit 1); exit 1; }' $ac_signal
- +done
- +ac_signal=0
- +
- +# confdefs.h avoids OS command line length limits that DEFS can exceed.
- +rm -rf conftest* confdefs.h
- +# AIX cpp loses on an empty file, so make sure it contains at least a newline.
- +echo >confdefs.h
- +
- +# Predefined preprocessor variables.
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE_NAME "$PACKAGE_NAME"
- +_ACEOF
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE_TARNAME "$PACKAGE_TARNAME"
- +_ACEOF
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE_VERSION "$PACKAGE_VERSION"
- +_ACEOF
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE_STRING "$PACKAGE_STRING"
- +_ACEOF
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE_BUGREPORT "$PACKAGE_BUGREPORT"
- +_ACEOF
- +
- +
- +# Let the site file select an alternate cache file if it wants to.
- +# Prefer explicitly selected file to automatically selected ones.
- +if test -z "$CONFIG_SITE"; then
- + if test "x$prefix" != xNONE; then
- + CONFIG_SITE="$prefix/share/config.site $prefix/etc/config.site"
- + else
- + CONFIG_SITE="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site"
- + fi
- +fi
- +for ac_site_file in $CONFIG_SITE; do
- + if test -r "$ac_site_file"; then
- + { echo "$as_me:$LINENO: loading site script $ac_site_file" >&5
- +echo "$as_me: loading site script $ac_site_file" >&6;}
- + sed 's/^/| /' "$ac_site_file" >&5
- + . "$ac_site_file"
- + fi
- +done
- +
- +if test -r "$cache_file"; then
- + # Some versions of bash will fail to source /dev/null (special
- + # files actually), so we avoid doing that.
- + if test -f "$cache_file"; then
- + { echo "$as_me:$LINENO: loading cache $cache_file" >&5
- +echo "$as_me: loading cache $cache_file" >&6;}
- + case $cache_file in
- + [\\/]* | ?:[\\/]* ) . $cache_file;;
- + *) . ./$cache_file;;
- + esac
- + fi
- +else
- + { echo "$as_me:$LINENO: creating cache $cache_file" >&5
- +echo "$as_me: creating cache $cache_file" >&6;}
- + >$cache_file
- +fi
- +
- +# Check that the precious variables saved in the cache have kept the same
- +# value.
- +ac_cache_corrupted=false
- +for ac_var in `(set) 2>&1 |
- + sed -n 's/^ac_env_\([a-zA-Z_0-9]*\)_set=.*/\1/p'`; do
- + eval ac_old_set=\$ac_cv_env_${ac_var}_set
- + eval ac_new_set=\$ac_env_${ac_var}_set
- + eval ac_old_val="\$ac_cv_env_${ac_var}_value"
- + eval ac_new_val="\$ac_env_${ac_var}_value"
- + case $ac_old_set,$ac_new_set in
- + set,)
- + { echo "$as_me:$LINENO: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5
- +echo "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;}
- + ac_cache_corrupted=: ;;
- + ,set)
- + { echo "$as_me:$LINENO: error: \`$ac_var' was not set in the previous run" >&5
- +echo "$as_me: error: \`$ac_var' was not set in the previous run" >&2;}
- + ac_cache_corrupted=: ;;
- + ,);;
- + *)
- + if test "x$ac_old_val" != "x$ac_new_val"; then
- + { echo "$as_me:$LINENO: error: \`$ac_var' has changed since the previous run:" >&5
- +echo "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;}
- + { echo "$as_me:$LINENO: former value: $ac_old_val" >&5
- +echo "$as_me: former value: $ac_old_val" >&2;}
- + { echo "$as_me:$LINENO: current value: $ac_new_val" >&5
- +echo "$as_me: current value: $ac_new_val" >&2;}
- + ac_cache_corrupted=:
- + fi;;
- + esac
- + # Pass precious variables to config.status.
- + if test "$ac_new_set" = set; then
- + case $ac_new_val in
- + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?\"\']*)
- + ac_arg=$ac_var=`echo "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;;
- + *) ac_arg=$ac_var=$ac_new_val ;;
- + esac
- + case " $ac_configure_args " in
- + *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy.
- + *) ac_configure_args="$ac_configure_args '$ac_arg'" ;;
- + esac
- + fi
- +done
- +if $ac_cache_corrupted; then
- + { echo "$as_me:$LINENO: error: changes in the environment can compromise the build" >&5
- +echo "$as_me: error: changes in the environment can compromise the build" >&2;}
- + { { echo "$as_me:$LINENO: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&5
- +echo "$as_me: error: run \`make distclean' and/or \`rm $cache_file' and start over" >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +
- +ac_ext=c
- +ac_cpp='$CPP $CPPFLAGS'
- +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
- +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
- +ac_compiler_gnu=$ac_cv_c_compiler_gnu
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +
- +am__api_version="1.8"
- +ac_aux_dir=
- +for ac_dir in $srcdir $srcdir/.. $srcdir/../..; do
- + if test -f $ac_dir/install-sh; then
- + ac_aux_dir=$ac_dir
- + ac_install_sh="$ac_aux_dir/install-sh -c"
- + break
- + elif test -f $ac_dir/install.sh; then
- + ac_aux_dir=$ac_dir
- + ac_install_sh="$ac_aux_dir/install.sh -c"
- + break
- + elif test -f $ac_dir/shtool; then
- + ac_aux_dir=$ac_dir
- + ac_install_sh="$ac_aux_dir/shtool install -c"
- + break
- + fi
- +done
- +if test -z "$ac_aux_dir"; then
- + { { echo "$as_me:$LINENO: error: cannot find install-sh or install.sh in $srcdir $srcdir/.. $srcdir/../.." >&5
- +echo "$as_me: error: cannot find install-sh or install.sh in $srcdir $srcdir/.. $srcdir/../.." >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +ac_config_guess="$SHELL $ac_aux_dir/config.guess"
- +ac_config_sub="$SHELL $ac_aux_dir/config.sub"
- +ac_configure="$SHELL $ac_aux_dir/configure" # This should be Cygnus configure.
- +
- +# Find a good install program. We prefer a C program (faster),
- +# so one script is as good as another. But avoid the broken or
- +# incompatible versions:
- +# SysV /etc/install, /usr/sbin/install
- +# SunOS /usr/etc/install
- +# IRIX /sbin/install
- +# AIX /bin/install
- +# AmigaOS /C/install, which installs bootblocks on floppy discs
- +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag
- +# AFS /usr/afsws/bin/install, which mishandles nonexistent args
- +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff"
- +# OS/2's system install, which has a completely different semantic
- +# ./install, which can be erroneously created by make from ./install.sh.
- +echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5
- +echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6
- +if test -z "$INSTALL"; then
- +if test "${ac_cv_path_install+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + # Account for people who put trailing slashes in PATH elements.
- +case $as_dir/ in
- + ./ | .// | /cC/* | \
- + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \
- + ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \
- + /usr/ucb/* ) ;;
- + *)
- + # OSF1 and SCO ODT 3.0 have their own names for install.
- + # Don't use installbsd from OSF since it installs stuff as root
- + # by default.
- + for ac_prog in ginstall scoinst install; do
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then
- + if test $ac_prog = install &&
- + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
- + # AIX install. It has an incompatible calling convention.
- + :
- + elif test $ac_prog = install &&
- + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
- + # program-specific install script used by HP pwplus--don't use.
- + :
- + else
- + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c"
- + break 3
- + fi
- + fi
- + done
- + done
- + ;;
- +esac
- +done
- +
- +
- +fi
- + if test "${ac_cv_path_install+set}" = set; then
- + INSTALL=$ac_cv_path_install
- + else
- + # As a last resort, use the slow shell script. We don't cache a
- + # path for INSTALL within a source directory, because that will
- + # break other packages using the cache if that directory is
- + # removed, or if the path is relative.
- + INSTALL=$ac_install_sh
- + fi
- +fi
- +echo "$as_me:$LINENO: result: $INSTALL" >&5
- +echo "${ECHO_T}$INSTALL" >&6
- +
- +# Use test -z because SunOS4 sh mishandles braces in ${var-val}.
- +# It thinks the first close brace ends the variable substitution.
- +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}'
- +
- +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}'
- +
- +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644'
- +
- +echo "$as_me:$LINENO: checking whether build environment is sane" >&5
- +echo $ECHO_N "checking whether build environment is sane... $ECHO_C" >&6
- +# Just in case
- +sleep 1
- +echo timestamp > conftest.file
- +# Do `set' in a subshell so we don't clobber the current shell's
- +# arguments. Must try -L first in case configure is actually a
- +# symlink; some systems play weird games with the mod time of symlinks
- +# (eg FreeBSD returns the mod time of the symlink's containing
- +# directory).
- +if (
- + set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null`
- + if test "$*" = "X"; then
- + # -L didn't work.
- + set X `ls -t $srcdir/configure conftest.file`
- + fi
- + rm -f conftest.file
- + if test "$*" != "X $srcdir/configure conftest.file" \
- + && test "$*" != "X conftest.file $srcdir/configure"; then
- +
- + # If neither matched, then we have a broken ls. This can happen
- + # if, for instance, CONFIG_SHELL is bash and it inherits a
- + # broken ls alias from the environment. This has actually
- + # happened. Such a system could not be considered "sane".
- + { { echo "$as_me:$LINENO: error: ls -t appears to fail. Make sure there is not a broken
- +alias in your environment" >&5
- +echo "$as_me: error: ls -t appears to fail. Make sure there is not a broken
- +alias in your environment" >&2;}
- + { (exit 1); exit 1; }; }
- + fi
- +
- + test "$2" = conftest.file
- + )
- +then
- + # Ok.
- + :
- +else
- + { { echo "$as_me:$LINENO: error: newly created file is older than distributed files!
- +Check your system clock" >&5
- +echo "$as_me: error: newly created file is older than distributed files!
- +Check your system clock" >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +echo "$as_me:$LINENO: result: yes" >&5
- +echo "${ECHO_T}yes" >&6
- +test "$program_prefix" != NONE &&
- + program_transform_name="s,^,$program_prefix,;$program_transform_name"
- +# Use a double $ so make ignores it.
- +test "$program_suffix" != NONE &&
- + program_transform_name="s,\$,$program_suffix,;$program_transform_name"
- +# Double any \ or $. echo might interpret backslashes.
- +# By default was `s,x,x', remove it if useless.
- +cat <<\_ACEOF >conftest.sed
- +s/[\\$]/&&/g;s/;s,x,x,$//
- +_ACEOF
- +program_transform_name=`echo $program_transform_name | sed -f conftest.sed`
- +rm conftest.sed
- +
- +# expand $ac_aux_dir to an absolute path
- +am_aux_dir=`cd $ac_aux_dir && pwd`
- +
- +test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing"
- +# Use eval to expand $SHELL
- +if eval "$MISSING --run true"; then
- + am_missing_run="$MISSING --run "
- +else
- + am_missing_run=
- + { echo "$as_me:$LINENO: WARNING: \`missing' script is too old or missing" >&5
- +echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;}
- +fi
- +
- +if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then
- + # Keeping the `.' argument allows $(mkdir_p) to be used without
- + # argument. Indeed, we sometimes output rules like
- + # $(mkdir_p) $(somedir)
- + # where $(somedir) is conditionally defined.
- + # (`test -n '$(somedir)' && $(mkdir_p) $(somedir)' is a more
- + # expensive solution, as it forces Make to start a sub-shell.)
- + mkdir_p='mkdir -p -- .'
- +else
- + # On NextStep and OpenStep, the `mkdir' command does not
- + # recognize any option. It will interpret all options as
- + # directories to create, and then abort because `.' already
- + # exists.
- + for d in ./-p ./--version;
- + do
- + test -d $d && rmdir $d
- + done
- + # $(mkinstalldirs) is defined by Automake if mkinstalldirs exists.
- + if test -f "$ac_aux_dir/mkinstalldirs"; then
- + mkdir_p='$(mkinstalldirs)'
- + else
- + mkdir_p='$(install_sh) -d'
- + fi
- +fi
- +
- +for ac_prog in gawk mawk nawk awk
- +do
- + # Extract the first word of "$ac_prog", so it can be a program name with args.
- +set dummy $ac_prog; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_AWK+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$AWK"; then
- + ac_cv_prog_AWK="$AWK" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_AWK="$ac_prog"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +AWK=$ac_cv_prog_AWK
- +if test -n "$AWK"; then
- + echo "$as_me:$LINENO: result: $AWK" >&5
- +echo "${ECHO_T}$AWK" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + test -n "$AWK" && break
- +done
- +
- +echo "$as_me:$LINENO: checking whether ${MAKE-make} sets \$(MAKE)" >&5
- +echo $ECHO_N "checking whether ${MAKE-make} sets \$(MAKE)... $ECHO_C" >&6
- +set dummy ${MAKE-make}; ac_make=`echo "$2" | sed 'y,:./+-,___p_,'`
- +if eval "test \"\${ac_cv_prog_make_${ac_make}_set+set}\" = set"; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + cat >conftest.make <<\_ACEOF
- +all:
- + @echo 'ac_maketemp="$(MAKE)"'
- +_ACEOF
- +# GNU make sometimes prints "make[1]: Entering...", which would confuse us.
- +eval `${MAKE-make} -f conftest.make 2>/dev/null | grep temp=`
- +if test -n "$ac_maketemp"; then
- + eval ac_cv_prog_make_${ac_make}_set=yes
- +else
- + eval ac_cv_prog_make_${ac_make}_set=no
- +fi
- +rm -f conftest.make
- +fi
- +if eval "test \"`echo '$ac_cv_prog_make_'${ac_make}_set`\" = yes"; then
- + echo "$as_me:$LINENO: result: yes" >&5
- +echo "${ECHO_T}yes" >&6
- + SET_MAKE=
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- + SET_MAKE="MAKE=${MAKE-make}"
- +fi
- +
- +rm -rf .tst 2>/dev/null
- +mkdir .tst 2>/dev/null
- +if test -d .tst; then
- + am__leading_dot=.
- +else
- + am__leading_dot=_
- +fi
- +rmdir .tst 2>/dev/null
- +
- +# test to see if srcdir already configured
- +if test "`cd $srcdir && pwd`" != "`pwd`" &&
- + test -f $srcdir/config.status; then
- + { { echo "$as_me:$LINENO: error: source directory already configured; run \"make distclean\" there first" >&5
- +echo "$as_me: error: source directory already configured; run \"make distclean\" there first" >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +
- +# test whether we have cygpath
- +if test -z "$CYGPATH_W"; then
- + if (cygpath --version) >/dev/null 2>/dev/null; then
- + CYGPATH_W='cygpath -w'
- + else
- + CYGPATH_W=echo
- + fi
- +fi
- +
- +
- +# Define the identity of the package.
- + PACKAGE=genext2fs
- + VERSION=1.3
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define PACKAGE "$PACKAGE"
- +_ACEOF
- +
- +
- +cat >>confdefs.h <<_ACEOF
- +#define VERSION "$VERSION"
- +_ACEOF
- +
- +# Some tools Automake needs.
- +
- +ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"}
- +
- +
- +AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"}
- +
- +
- +AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"}
- +
- +
- +AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"}
- +
- +
- +MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
- +
- +
- +AMTAR=${AMTAR-"${am_missing_run}tar"}
- +
- +install_sh=${install_sh-"$am_aux_dir/install-sh"}
- +
- +# Installed binaries are usually stripped using `strip' when the user
- +# run `make install-strip'. However `strip' might not be the right
- +# tool to use in cross-compilation environments, therefore Automake
- +# will honor the `STRIP' environment variable to overrule this program.
- +if test "$cross_compiling" != no; then
- + if test -n "$ac_tool_prefix"; then
- + # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args.
- +set dummy ${ac_tool_prefix}strip; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_STRIP+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$STRIP"; then
- + ac_cv_prog_STRIP="$STRIP" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_STRIP="${ac_tool_prefix}strip"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +STRIP=$ac_cv_prog_STRIP
- +if test -n "$STRIP"; then
- + echo "$as_me:$LINENO: result: $STRIP" >&5
- +echo "${ECHO_T}$STRIP" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- +fi
- +if test -z "$ac_cv_prog_STRIP"; then
- + ac_ct_STRIP=$STRIP
- + # Extract the first word of "strip", so it can be a program name with args.
- +set dummy strip; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$ac_ct_STRIP"; then
- + ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_ac_ct_STRIP="strip"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- + test -z "$ac_cv_prog_ac_ct_STRIP" && ac_cv_prog_ac_ct_STRIP=":"
- +fi
- +fi
- +ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP
- +if test -n "$ac_ct_STRIP"; then
- + echo "$as_me:$LINENO: result: $ac_ct_STRIP" >&5
- +echo "${ECHO_T}$ac_ct_STRIP" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + STRIP=$ac_ct_STRIP
- +else
- + STRIP="$ac_cv_prog_STRIP"
- +fi
- +
- +fi
- +INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s"
- +
- +# We need awk for the "check" target. The system "awk" is bad on
- +# some platforms.
- +
- +
- +
- +ac_ext=c
- +ac_cpp='$CPP $CPPFLAGS'
- +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
- +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
- +ac_compiler_gnu=$ac_cv_c_compiler_gnu
- +if test -n "$ac_tool_prefix"; then
- + # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args.
- +set dummy ${ac_tool_prefix}gcc; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$CC"; then
- + ac_cv_prog_CC="$CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_CC="${ac_tool_prefix}gcc"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +CC=$ac_cv_prog_CC
- +if test -n "$CC"; then
- + echo "$as_me:$LINENO: result: $CC" >&5
- +echo "${ECHO_T}$CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- +fi
- +if test -z "$ac_cv_prog_CC"; then
- + ac_ct_CC=$CC
- + # Extract the first word of "gcc", so it can be a program name with args.
- +set dummy gcc; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$ac_ct_CC"; then
- + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_ac_ct_CC="gcc"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +ac_ct_CC=$ac_cv_prog_ac_ct_CC
- +if test -n "$ac_ct_CC"; then
- + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5
- +echo "${ECHO_T}$ac_ct_CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + CC=$ac_ct_CC
- +else
- + CC="$ac_cv_prog_CC"
- +fi
- +
- +if test -z "$CC"; then
- + if test -n "$ac_tool_prefix"; then
- + # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args.
- +set dummy ${ac_tool_prefix}cc; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$CC"; then
- + ac_cv_prog_CC="$CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_CC="${ac_tool_prefix}cc"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +CC=$ac_cv_prog_CC
- +if test -n "$CC"; then
- + echo "$as_me:$LINENO: result: $CC" >&5
- +echo "${ECHO_T}$CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- +fi
- +if test -z "$ac_cv_prog_CC"; then
- + ac_ct_CC=$CC
- + # Extract the first word of "cc", so it can be a program name with args.
- +set dummy cc; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$ac_ct_CC"; then
- + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_ac_ct_CC="cc"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +ac_ct_CC=$ac_cv_prog_ac_ct_CC
- +if test -n "$ac_ct_CC"; then
- + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5
- +echo "${ECHO_T}$ac_ct_CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + CC=$ac_ct_CC
- +else
- + CC="$ac_cv_prog_CC"
- +fi
- +
- +fi
- +if test -z "$CC"; then
- + # Extract the first word of "cc", so it can be a program name with args.
- +set dummy cc; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$CC"; then
- + ac_cv_prog_CC="$CC" # Let the user override the test.
- +else
- + ac_prog_rejected=no
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then
- + ac_prog_rejected=yes
- + continue
- + fi
- + ac_cv_prog_CC="cc"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +if test $ac_prog_rejected = yes; then
- + # We found a bogon in the path, so make sure we never use it.
- + set dummy $ac_cv_prog_CC
- + shift
- + if test $# != 0; then
- + # We chose a different compiler from the bogus one.
- + # However, it has the same basename, so the bogon will be chosen
- + # first if we set CC to just the basename; use the full file name.
- + shift
- + ac_cv_prog_CC="$as_dir/$ac_word${1+' '}$@"
- + fi
- +fi
- +fi
- +fi
- +CC=$ac_cv_prog_CC
- +if test -n "$CC"; then
- + echo "$as_me:$LINENO: result: $CC" >&5
- +echo "${ECHO_T}$CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- +fi
- +if test -z "$CC"; then
- + if test -n "$ac_tool_prefix"; then
- + for ac_prog in cl
- + do
- + # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args.
- +set dummy $ac_tool_prefix$ac_prog; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$CC"; then
- + ac_cv_prog_CC="$CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_CC="$ac_tool_prefix$ac_prog"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +CC=$ac_cv_prog_CC
- +if test -n "$CC"; then
- + echo "$as_me:$LINENO: result: $CC" >&5
- +echo "${ECHO_T}$CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + test -n "$CC" && break
- + done
- +fi
- +if test -z "$CC"; then
- + ac_ct_CC=$CC
- + for ac_prog in cl
- +do
- + # Extract the first word of "$ac_prog", so it can be a program name with args.
- +set dummy $ac_prog; ac_word=$2
- +echo "$as_me:$LINENO: checking for $ac_word" >&5
- +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6
- +if test "${ac_cv_prog_ac_ct_CC+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -n "$ac_ct_CC"; then
- + ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test.
- +else
- +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- + ac_cv_prog_ac_ct_CC="$ac_prog"
- + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5
- + break 2
- + fi
- +done
- +done
- +
- +fi
- +fi
- +ac_ct_CC=$ac_cv_prog_ac_ct_CC
- +if test -n "$ac_ct_CC"; then
- + echo "$as_me:$LINENO: result: $ac_ct_CC" >&5
- +echo "${ECHO_T}$ac_ct_CC" >&6
- +else
- + echo "$as_me:$LINENO: result: no" >&5
- +echo "${ECHO_T}no" >&6
- +fi
- +
- + test -n "$ac_ct_CC" && break
- +done
- +
- + CC=$ac_ct_CC
- +fi
- +
- +fi
- +
- +
- +test -z "$CC" && { { echo "$as_me:$LINENO: error: no acceptable C compiler found in \$PATH
- +See \`config.log' for more details." >&5
- +echo "$as_me: error: no acceptable C compiler found in \$PATH
- +See \`config.log' for more details." >&2;}
- + { (exit 1); exit 1; }; }
- +
- +# Provide some information about the compiler.
- +echo "$as_me:$LINENO:" \
- + "checking for C compiler version" >&5
- +ac_compiler=`set X $ac_compile; echo $2`
- +{ (eval echo "$as_me:$LINENO: \"$ac_compiler --version </dev/null >&5\"") >&5
- + (eval $ac_compiler --version </dev/null >&5) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }
- +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -v </dev/null >&5\"") >&5
- + (eval $ac_compiler -v </dev/null >&5) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }
- +{ (eval echo "$as_me:$LINENO: \"$ac_compiler -V </dev/null >&5\"") >&5
- + (eval $ac_compiler -V </dev/null >&5) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }
- +
- +cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +
- +int
- +main ()
- +{
- +
- + ;
- + return 0;
- +}
- +_ACEOF
- +ac_clean_files_save=$ac_clean_files
- +ac_clean_files="$ac_clean_files a.out a.exe b.out"
- +# Try to create an executable without -o first, disregard a.out.
- +# It will help us diagnose broken compilers, and finding out an intuition
- +# of exeext.
- +echo "$as_me:$LINENO: checking for C compiler default output file name" >&5
- +echo $ECHO_N "checking for C compiler default output file name... $ECHO_C" >&6
- +ac_link_default=`echo "$ac_link" | sed 's/ -o *conftest[^ ]*//'`
- +if { (eval echo "$as_me:$LINENO: \"$ac_link_default\"") >&5
- + (eval $ac_link_default) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; then
- + # Find the output, starting from the most likely. This scheme is
- +# not robust to junk in `.', hence go to wildcards (a.*) only as a last
- +# resort.
- +
- +# Be careful to initialize this variable, since it used to be cached.
- +# Otherwise an old cache value of `no' led to `EXEEXT = no' in a Makefile.
- +ac_cv_exeext=
- +# b.out is created by i960 compilers.
- +for ac_file in a_out.exe a.exe conftest.exe a.out conftest a.* conftest.* b.out
- +do
- + test -f "$ac_file" || continue
- + case $ac_file in
- + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj )
- + ;;
- + conftest.$ac_ext )
- + # This is the source file.
- + ;;
- + [ab].out )
- + # We found the default executable, but exeext='' is most
- + # certainly right.
- + break;;
- + *.* )
- + ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'`
- + # FIXME: I believe we export ac_cv_exeext for Libtool,
- + # but it would be cool to find out if it's true. Does anybody
- + # maintain Libtool? --akim.
- + export ac_cv_exeext
- + break;;
- + * )
- + break;;
- + esac
- +done
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +{ { echo "$as_me:$LINENO: error: C compiler cannot create executables
- +See \`config.log' for more details." >&5
- +echo "$as_me: error: C compiler cannot create executables
- +See \`config.log' for more details." >&2;}
- + { (exit 77); exit 77; }; }
- +fi
- +
- +ac_exeext=$ac_cv_exeext
- +echo "$as_me:$LINENO: result: $ac_file" >&5
- +echo "${ECHO_T}$ac_file" >&6
- +
- +# Check the compiler produces executables we can run. If not, either
- +# the compiler is broken, or we cross compile.
- +echo "$as_me:$LINENO: checking whether the C compiler works" >&5
- +echo $ECHO_N "checking whether the C compiler works... $ECHO_C" >&6
- +# FIXME: These cross compiler hacks should be removed for Autoconf 3.0
- +# If not cross compiling, check that we can run a simple program.
- +if test "$cross_compiling" != yes; then
- + if { ac_try='./$ac_file'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + cross_compiling=no
- + else
- + if test "$cross_compiling" = maybe; then
- + cross_compiling=yes
- + else
- + { { echo "$as_me:$LINENO: error: cannot run C compiled programs.
- +If you meant to cross compile, use \`--host'.
- +See \`config.log' for more details." >&5
- +echo "$as_me: error: cannot run C compiled programs.
- +If you meant to cross compile, use \`--host'.
- +See \`config.log' for more details." >&2;}
- + { (exit 1); exit 1; }; }
- + fi
- + fi
- +fi
- +echo "$as_me:$LINENO: result: yes" >&5
- +echo "${ECHO_T}yes" >&6
- +
- +rm -f a.out a.exe conftest$ac_cv_exeext b.out
- +ac_clean_files=$ac_clean_files_save
- +# Check the compiler produces executables we can run. If not, either
- +# the compiler is broken, or we cross compile.
- +echo "$as_me:$LINENO: checking whether we are cross compiling" >&5
- +echo $ECHO_N "checking whether we are cross compiling... $ECHO_C" >&6
- +echo "$as_me:$LINENO: result: $cross_compiling" >&5
- +echo "${ECHO_T}$cross_compiling" >&6
- +
- +echo "$as_me:$LINENO: checking for suffix of executables" >&5
- +echo $ECHO_N "checking for suffix of executables... $ECHO_C" >&6
- +if { (eval echo "$as_me:$LINENO: \"$ac_link\"") >&5
- + (eval $ac_link) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; then
- + # If both `conftest.exe' and `conftest' are `present' (well, observable)
- +# catch `conftest.exe'. For instance with Cygwin, `ls conftest' will
- +# work properly (i.e., refer to `conftest.exe'), while it won't with
- +# `rm'.
- +for ac_file in conftest.exe conftest conftest.*; do
- + test -f "$ac_file" || continue
- + case $ac_file in
- + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.o | *.obj ) ;;
- + *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'`
- + export ac_cv_exeext
- + break;;
- + * ) break;;
- + esac
- +done
- +else
- + { { echo "$as_me:$LINENO: error: cannot compute suffix of executables: cannot compile and link
- +See \`config.log' for more details." >&5
- +echo "$as_me: error: cannot compute suffix of executables: cannot compile and link
- +See \`config.log' for more details." >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +
- +rm -f conftest$ac_cv_exeext
- +echo "$as_me:$LINENO: result: $ac_cv_exeext" >&5
- +echo "${ECHO_T}$ac_cv_exeext" >&6
- +
- +rm -f conftest.$ac_ext
- +EXEEXT=$ac_cv_exeext
- +ac_exeext=$EXEEXT
- +echo "$as_me:$LINENO: checking for suffix of object files" >&5
- +echo $ECHO_N "checking for suffix of object files... $ECHO_C" >&6
- +if test "${ac_cv_objext+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +
- +int
- +main ()
- +{
- +
- + ;
- + return 0;
- +}
- +_ACEOF
- +rm -f conftest.o conftest.obj
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; then
- + for ac_file in `(ls conftest.o conftest.obj; ls conftest.*) 2>/dev/null`; do
- + case $ac_file in
- + *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg ) ;;
- + *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'`
- + break;;
- + esac
- +done
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +{ { echo "$as_me:$LINENO: error: cannot compute suffix of object files: cannot compile
- +See \`config.log' for more details." >&5
- +echo "$as_me: error: cannot compute suffix of object files: cannot compile
- +See \`config.log' for more details." >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +
- +rm -f conftest.$ac_cv_objext conftest.$ac_ext
- +fi
- +echo "$as_me:$LINENO: result: $ac_cv_objext" >&5
- +echo "${ECHO_T}$ac_cv_objext" >&6
- +OBJEXT=$ac_cv_objext
- +ac_objext=$OBJEXT
- +echo "$as_me:$LINENO: checking whether we are using the GNU C compiler" >&5
- +echo $ECHO_N "checking whether we are using the GNU C compiler... $ECHO_C" >&6
- +if test "${ac_cv_c_compiler_gnu+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +
- +int
- +main ()
- +{
- +#ifndef __GNUC__
- + choke me
- +#endif
- +
- + ;
- + return 0;
- +}
- +_ACEOF
- +rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + ac_compiler_gnu=yes
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +ac_compiler_gnu=no
- +fi
- +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
- +ac_cv_c_compiler_gnu=$ac_compiler_gnu
- +
- +fi
- +echo "$as_me:$LINENO: result: $ac_cv_c_compiler_gnu" >&5
- +echo "${ECHO_T}$ac_cv_c_compiler_gnu" >&6
- +GCC=`test $ac_compiler_gnu = yes && echo yes`
- +ac_test_CFLAGS=${CFLAGS+set}
- +ac_save_CFLAGS=$CFLAGS
- +CFLAGS="-g"
- +echo "$as_me:$LINENO: checking whether $CC accepts -g" >&5
- +echo $ECHO_N "checking whether $CC accepts -g... $ECHO_C" >&6
- +if test "${ac_cv_prog_cc_g+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +
- +int
- +main ()
- +{
- +
- + ;
- + return 0;
- +}
- +_ACEOF
- +rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + ac_cv_prog_cc_g=yes
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +ac_cv_prog_cc_g=no
- +fi
- +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
- +fi
- +echo "$as_me:$LINENO: result: $ac_cv_prog_cc_g" >&5
- +echo "${ECHO_T}$ac_cv_prog_cc_g" >&6
- +if test "$ac_test_CFLAGS" = set; then
- + CFLAGS=$ac_save_CFLAGS
- +elif test $ac_cv_prog_cc_g = yes; then
- + if test "$GCC" = yes; then
- + CFLAGS="-g -O2"
- + else
- + CFLAGS="-g"
- + fi
- +else
- + if test "$GCC" = yes; then
- + CFLAGS="-O2"
- + else
- + CFLAGS=
- + fi
- +fi
- +echo "$as_me:$LINENO: checking for $CC option to accept ANSI C" >&5
- +echo $ECHO_N "checking for $CC option to accept ANSI C... $ECHO_C" >&6
- +if test "${ac_cv_prog_cc_stdc+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + ac_cv_prog_cc_stdc=no
- +ac_save_CC=$CC
- +cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +#include <stdarg.h>
- +#include <stdio.h>
- +#include <sys/types.h>
- +#include <sys/stat.h>
- +/* Most of the following tests are stolen from RCS 5.7's src/conf.sh. */
- +struct buf { int x; };
- +FILE * (*rcsopen) (struct buf *, struct stat *, int);
- +static char *e (p, i)
- + char **p;
- + int i;
- +{
- + return p[i];
- +}
- +static char *f (char * (*g) (char **, int), char **p, ...)
- +{
- + char *s;
- + va_list v;
- + va_start (v,p);
- + s = g (p, va_arg (v,int));
- + va_end (v);
- + return s;
- +}
- +
- +/* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has
- + function prototypes and stuff, but not '\xHH' hex character constants.
- + These don't provoke an error unfortunately, instead are silently treated
- + as 'x'. The following induces an error, until -std1 is added to get
- + proper ANSI mode. Curiously '\x00'!='x' always comes out true, for an
- + array size at least. It's necessary to write '\x00'==0 to get something
- + that's true only with -std1. */
- +int osf4_cc_array ['\x00' == 0 ? 1 : -1];
- +
- +int test (int i, double x);
- +struct s1 {int (*f) (int a);};
- +struct s2 {int (*f) (double a);};
- +int pairnames (int, char **, FILE *(*)(struct buf *, struct stat *, int), int, int);
- +int argc;
- +char **argv;
- +int
- +main ()
- +{
- +return f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1];
- + ;
- + return 0;
- +}
- +_ACEOF
- +# Don't try gcc -ansi; that turns off useful extensions and
- +# breaks some systems' header files.
- +# AIX -qlanglvl=ansi
- +# Ultrix and OSF/1 -std1
- +# HP-UX 10.20 and later -Ae
- +# HP-UX older versions -Aa -D_HPUX_SOURCE
- +# SVR4 -Xc -D__EXTENSIONS__
- +for ac_arg in "" -qlanglvl=ansi -std1 -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__"
- +do
- + CC="$ac_save_CC $ac_arg"
- + rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + ac_cv_prog_cc_stdc=$ac_arg
- +break
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +fi
- +rm -f conftest.err conftest.$ac_objext
- +done
- +rm -f conftest.$ac_ext conftest.$ac_objext
- +CC=$ac_save_CC
- +
- +fi
- +
- +case "x$ac_cv_prog_cc_stdc" in
- + x|xno)
- + echo "$as_me:$LINENO: result: none needed" >&5
- +echo "${ECHO_T}none needed" >&6 ;;
- + *)
- + echo "$as_me:$LINENO: result: $ac_cv_prog_cc_stdc" >&5
- +echo "${ECHO_T}$ac_cv_prog_cc_stdc" >&6
- + CC="$CC $ac_cv_prog_cc_stdc" ;;
- +esac
- +
- +# Some people use a C++ compiler to compile C. Since we use `exit',
- +# in C++ we need to declare it. In case someone uses the same compiler
- +# for both compiling C and C++ we need to have the C++ compiler decide
- +# the declaration of exit, since it's the most demanding environment.
- +cat >conftest.$ac_ext <<_ACEOF
- +#ifndef __cplusplus
- + choke me
- +#endif
- +_ACEOF
- +rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + for ac_declaration in \
- + '' \
- + 'extern "C" void std::exit (int) throw (); using std::exit;' \
- + 'extern "C" void std::exit (int); using std::exit;' \
- + 'extern "C" void exit (int) throw ();' \
- + 'extern "C" void exit (int);' \
- + 'void exit (int);'
- +do
- + cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +$ac_declaration
- +#include <stdlib.h>
- +int
- +main ()
- +{
- +exit (42);
- + ;
- + return 0;
- +}
- +_ACEOF
- +rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + :
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +continue
- +fi
- +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
- + cat >conftest.$ac_ext <<_ACEOF
- +/* confdefs.h. */
- +_ACEOF
- +cat confdefs.h >>conftest.$ac_ext
- +cat >>conftest.$ac_ext <<_ACEOF
- +/* end confdefs.h. */
- +$ac_declaration
- +int
- +main ()
- +{
- +exit (42);
- + ;
- + return 0;
- +}
- +_ACEOF
- +rm -f conftest.$ac_objext
- +if { (eval echo "$as_me:$LINENO: \"$ac_compile\"") >&5
- + (eval $ac_compile) 2>conftest.er1
- + ac_status=$?
- + grep -v '^ *+' conftest.er1 >conftest.err
- + rm -f conftest.er1
- + cat conftest.err >&5
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); } &&
- + { ac_try='test -z "$ac_c_werror_flag" || test ! -s conftest.err'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; } &&
- + { ac_try='test -s conftest.$ac_objext'
- + { (eval echo "$as_me:$LINENO: \"$ac_try\"") >&5
- + (eval $ac_try) 2>&5
- + ac_status=$?
- + echo "$as_me:$LINENO: \$? = $ac_status" >&5
- + (exit $ac_status); }; }; then
- + break
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +fi
- +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
- +done
- +rm -f conftest*
- +if test -n "$ac_declaration"; then
- + echo '#ifdef __cplusplus' >>confdefs.h
- + echo $ac_declaration >>confdefs.h
- + echo '#endif' >>confdefs.h
- +fi
- +
- +else
- + echo "$as_me: failed program was:" >&5
- +sed 's/^/| /' conftest.$ac_ext >&5
- +
- +fi
- +rm -f conftest.err conftest.$ac_objext conftest.$ac_ext
- +ac_ext=c
- +ac_cpp='$CPP $CPPFLAGS'
- +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
- +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
- +ac_compiler_gnu=$ac_cv_c_compiler_gnu
- +DEPDIR="${am__leading_dot}deps"
- +
- + ac_config_commands="$ac_config_commands depfiles"
- +
- +
- +am_make=${MAKE-make}
- +cat > confinc << 'END'
- +am__doit:
- + @echo done
- +.PHONY: am__doit
- +END
- +# If we don't find an include directive, just comment out the code.
- +echo "$as_me:$LINENO: checking for style of include used by $am_make" >&5
- +echo $ECHO_N "checking for style of include used by $am_make... $ECHO_C" >&6
- +am__include="#"
- +am__quote=
- +_am_result=none
- +# First try GNU make style include.
- +echo "include confinc" > confmf
- +# We grep out `Entering directory' and `Leaving directory'
- +# messages which can occur if `w' ends up in MAKEFLAGS.
- +# In particular we don't look at `^make:' because GNU make might
- +# be invoked under some other name (usually "gmake"), in which
- +# case it prints its new name instead of `make'.
- +if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then
- + am__include=include
- + am__quote=
- + _am_result=GNU
- +fi
- +# Now try BSD make style include.
- +if test "$am__include" = "#"; then
- + echo '.include "confinc"' > confmf
- + if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then
- + am__include=.include
- + am__quote="\""
- + _am_result=BSD
- + fi
- +fi
- +
- +
- +echo "$as_me:$LINENO: result: $_am_result" >&5
- +echo "${ECHO_T}$_am_result" >&6
- +rm -f confinc confmf
- +
- +# Check whether --enable-dependency-tracking or --disable-dependency-tracking was given.
- +if test "${enable_dependency_tracking+set}" = set; then
- + enableval="$enable_dependency_tracking"
- +
- +fi;
- +if test "x$enable_dependency_tracking" != xno; then
- + am_depcomp="$ac_aux_dir/depcomp"
- + AMDEPBACKSLASH='\'
- +fi
- +
- +
- +if test "x$enable_dependency_tracking" != xno; then
- + AMDEP_TRUE=
- + AMDEP_FALSE='#'
- +else
- + AMDEP_TRUE='#'
- + AMDEP_FALSE=
- +fi
- +
- +
- +
- +
- +depcc="$CC" am_compiler_list=
- +
- +echo "$as_me:$LINENO: checking dependency style of $depcc" >&5
- +echo $ECHO_N "checking dependency style of $depcc... $ECHO_C" >&6
- +if test "${am_cv_CC_dependencies_compiler_type+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
- + # We make a subdir and do the tests there. Otherwise we can end up
- + # making bogus files that we don't know about and never remove. For
- + # instance it was reported that on HP-UX the gcc test will end up
- + # making a dummy file named `D' -- because `-MD' means `put the output
- + # in D'.
- + mkdir conftest.dir
- + # Copy depcomp to subdir because otherwise we won't find it if we're
- + # using a relative directory.
- + cp "$am_depcomp" conftest.dir
- + cd conftest.dir
- + # We will build objects and dependencies in a subdirectory because
- + # it helps to detect inapplicable dependency modes. For instance
- + # both Tru64's cc and ICC support -MD to output dependencies as a
- + # side effect of compilation, but ICC will put the dependencies in
- + # the current directory while Tru64 will put them in the object
- + # directory.
- + mkdir sub
- +
- + am_cv_CC_dependencies_compiler_type=none
- + if test "$am_compiler_list" = ""; then
- + am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp`
- + fi
- + for depmode in $am_compiler_list; do
- + # Setup a source with many dependencies, because some compilers
- + # like to wrap large dependency lists on column 80 (with \), and
- + # we should not choose a depcomp mode which is confused by this.
- + #
- + # We need to recreate these files for each test, as the compiler may
- + # overwrite some of them when testing with obscure command lines.
- + # This happens at least with the AIX C compiler.
- + : > sub/conftest.c
- + for i in 1 2 3 4 5 6; do
- + echo '#include "conftst'$i'.h"' >> sub/conftest.c
- + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with
- + # Solaris 8's {/usr,}/bin/sh.
- + touch sub/conftst$i.h
- + done
- + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
- +
- + case $depmode in
- + nosideeffect)
- + # after this tag, mechanisms are not by side-effect, so they'll
- + # only be used when explicitly requested
- + if test "x$enable_dependency_tracking" = xyes; then
- + continue
- + else
- + break
- + fi
- + ;;
- + none) break ;;
- + esac
- + # We check with `-c' and `-o' for the sake of the "dashmstdout"
- + # mode. It turns out that the SunPro C++ compiler does not properly
- + # handle `-M -o', and we need to detect this.
- + if depmode=$depmode \
- + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \
- + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
- + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \
- + >/dev/null 2>conftest.err &&
- + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
- + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 &&
- + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then
- + # icc doesn't choke on unknown options, it will just issue warnings
- + # or remarks (even with -Werror). So we grep stderr for any message
- + # that says an option was ignored or not supported.
- + # When given -MP, icc 7.0 and 7.1 complain thusly:
- + # icc: Command line warning: ignoring option '-M'; no argument required
- + # The diagnosis changed in icc 8.0:
- + # icc: Command line remark: option '-MP' not supported
- + if (grep 'ignoring option' conftest.err ||
- + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
- + am_cv_CC_dependencies_compiler_type=$depmode
- + break
- + fi
- + fi
- + done
- +
- + cd ..
- + rm -rf conftest.dir
- +else
- + am_cv_CC_dependencies_compiler_type=none
- +fi
- +
- +fi
- +echo "$as_me:$LINENO: result: $am_cv_CC_dependencies_compiler_type" >&5
- +echo "${ECHO_T}$am_cv_CC_dependencies_compiler_type" >&6
- +CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type
- +
- +
- +
- +if
- + test "x$enable_dependency_tracking" != xno \
- + && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then
- + am__fastdepCC_TRUE=
- + am__fastdepCC_FALSE='#'
- +else
- + am__fastdepCC_TRUE='#'
- + am__fastdepCC_FALSE=
- +fi
- +
- +
- +# Find a good install program. We prefer a C program (faster),
- +# so one script is as good as another. But avoid the broken or
- +# incompatible versions:
- +# SysV /etc/install, /usr/sbin/install
- +# SunOS /usr/etc/install
- +# IRIX /sbin/install
- +# AIX /bin/install
- +# AmigaOS /C/install, which installs bootblocks on floppy discs
- +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag
- +# AFS /usr/afsws/bin/install, which mishandles nonexistent args
- +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff"
- +# OS/2's system install, which has a completely different semantic
- +# ./install, which can be erroneously created by make from ./install.sh.
- +echo "$as_me:$LINENO: checking for a BSD-compatible install" >&5
- +echo $ECHO_N "checking for a BSD-compatible install... $ECHO_C" >&6
- +if test -z "$INSTALL"; then
- +if test "${ac_cv_path_install+set}" = set; then
- + echo $ECHO_N "(cached) $ECHO_C" >&6
- +else
- + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + # Account for people who put trailing slashes in PATH elements.
- +case $as_dir/ in
- + ./ | .// | /cC/* | \
- + /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \
- + ?:\\/os2\\/install\\/* | ?:\\/OS2\\/INSTALL\\/* | \
- + /usr/ucb/* ) ;;
- + *)
- + # OSF1 and SCO ODT 3.0 have their own names for install.
- + # Don't use installbsd from OSF since it installs stuff as root
- + # by default.
- + for ac_prog in ginstall scoinst install; do
- + for ac_exec_ext in '' $ac_executable_extensions; do
- + if $as_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then
- + if test $ac_prog = install &&
- + grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
- + # AIX install. It has an incompatible calling convention.
- + :
- + elif test $ac_prog = install &&
- + grep pwplus "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then
- + # program-specific install script used by HP pwplus--don't use.
- + :
- + else
- + ac_cv_path_install="$as_dir/$ac_prog$ac_exec_ext -c"
- + break 3
- + fi
- + fi
- + done
- + done
- + ;;
- +esac
- +done
- +
- +
- +fi
- + if test "${ac_cv_path_install+set}" = set; then
- + INSTALL=$ac_cv_path_install
- + else
- + # As a last resort, use the slow shell script. We don't cache a
- + # path for INSTALL within a source directory, because that will
- + # break other packages using the cache if that directory is
- + # removed, or if the path is relative.
- + INSTALL=$ac_install_sh
- + fi
- +fi
- +echo "$as_me:$LINENO: result: $INSTALL" >&5
- +echo "${ECHO_T}$INSTALL" >&6
- +
- +# Use test -z because SunOS4 sh mishandles braces in ${var-val}.
- +# It thinks the first close brace ends the variable substitution.
- +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}'
- +
- +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}'
- +
- +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644'
- +
- + ac_config_files="$ac_config_files Makefile"
- +cat >confcache <<\_ACEOF
- +# This file is a shell script that caches the results of configure
- +# tests run on this system so they can be shared between configure
- +# scripts and configure runs, see configure's option --config-cache.
- +# It is not useful on other systems. If it contains results you don't
- +# want to keep, you may remove or edit it.
- +#
- +# config.status only pays attention to the cache file if you give it
- +# the --recheck option to rerun configure.
- +#
- +# `ac_cv_env_foo' variables (set or unset) will be overridden when
- +# loading this file, other *unset* `ac_cv_foo' will be assigned the
- +# following values.
- +
- +_ACEOF
- +
- +# The following way of writing the cache mishandles newlines in values,
- +# but we know of no workaround that is simple, portable, and efficient.
- +# So, don't put newlines in cache variables' values.
- +# Ultrix sh set writes to stderr and can't be redirected directly,
- +# and sets the high bit in the cache file unless we assign to the vars.
- +{
- + (set) 2>&1 |
- + case `(ac_space=' '; set | grep ac_space) 2>&1` in
- + *ac_space=\ *)
- + # `set' does not quote correctly, so add quotes (double-quote
- + # substitution turns \\\\ into \\, and sed turns \\ into \).
- + sed -n \
- + "s/'/'\\\\''/g;
- + s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p"
- + ;;
- + *)
- + # `set' quotes correctly as required by POSIX, so do not add quotes.
- + sed -n \
- + "s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1=\\2/p"
- + ;;
- + esac;
- +} |
- + sed '
- + t clear
- + : clear
- + s/^\([^=]*\)=\(.*[{}].*\)$/test "${\1+set}" = set || &/
- + t end
- + /^ac_cv_env/!s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/
- + : end' >>confcache
- +if diff $cache_file confcache >/dev/null 2>&1; then :; else
- + if test -w $cache_file; then
- + test "x$cache_file" != "x/dev/null" && echo "updating cache $cache_file"
- + cat confcache >$cache_file
- + else
- + echo "not updating unwritable cache $cache_file"
- + fi
- +fi
- +rm -f confcache
- +
- +test "x$prefix" = xNONE && prefix=$ac_default_prefix
- +# Let make expand exec_prefix.
- +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}'
- +
- +# VPATH may cause trouble with some makes, so we remove $(srcdir),
- +# ${srcdir} and @srcdir@ from VPATH if srcdir is ".", strip leading and
- +# trailing colons and then remove the whole line if VPATH becomes empty
- +# (actually we leave an empty line to preserve line numbers).
- +if test "x$srcdir" = x.; then
- + ac_vpsub='/^[ ]*VPATH[ ]*=/{
- +s/:*\$(srcdir):*/:/;
- +s/:*\${srcdir}:*/:/;
- +s/:*@srcdir@:*/:/;
- +s/^\([^=]*=[ ]*\):*/\1/;
- +s/:*$//;
- +s/^[^=]*=[ ]*$//;
- +}'
- +fi
- +
- +# Transform confdefs.h into DEFS.
- +# Protect against shell expansion while executing Makefile rules.
- +# Protect against Makefile macro expansion.
- +#
- +# If the first sed substitution is executed (which looks for macros that
- +# take arguments), then we branch to the quote section. Otherwise,
- +# look for a macro that doesn't take arguments.
- +cat >confdef2opt.sed <<\_ACEOF
- +t clear
- +: clear
- +s,^[ ]*#[ ]*define[ ][ ]*\([^ (][^ (]*([^)]*)\)[ ]*\(.*\),-D\1=\2,g
- +t quote
- +s,^[ ]*#[ ]*define[ ][ ]*\([^ ][^ ]*\)[ ]*\(.*\),-D\1=\2,g
- +t quote
- +d
- +: quote
- +s,[ `~#$^&*(){}\\|;'"<>?],\\&,g
- +s,\[,\\&,g
- +s,\],\\&,g
- +s,\$,$$,g
- +p
- +_ACEOF
- +# We use echo to avoid assuming a particular line-breaking character.
- +# The extra dot is to prevent the shell from consuming trailing
- +# line-breaks from the sub-command output. A line-break within
- +# single-quotes doesn't work because, if this script is created in a
- +# platform that uses two characters for line-breaks (e.g., DOS), tr
- +# would break.
- +ac_LF_and_DOT=`echo; echo .`
- +DEFS=`sed -n -f confdef2opt.sed confdefs.h | tr "$ac_LF_and_DOT" ' .'`
- +rm -f confdef2opt.sed
- +
- +
- +ac_libobjs=
- +ac_ltlibobjs=
- +for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue
- + # 1. Remove the extension, and $U if already installed.
- + ac_i=`echo "$ac_i" |
- + sed 's/\$U\././;s/\.o$//;s/\.obj$//'`
- + # 2. Add them.
- + ac_libobjs="$ac_libobjs $ac_i\$U.$ac_objext"
- + ac_ltlibobjs="$ac_ltlibobjs $ac_i"'$U.lo'
- +done
- +LIBOBJS=$ac_libobjs
- +
- +LTLIBOBJS=$ac_ltlibobjs
- +
- +
- +if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then
- + { { echo "$as_me:$LINENO: error: conditional \"AMDEP\" was never defined.
- +Usually this means the macro was only invoked conditionally." >&5
- +echo "$as_me: error: conditional \"AMDEP\" was never defined.
- +Usually this means the macro was only invoked conditionally." >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then
- + { { echo "$as_me:$LINENO: error: conditional \"am__fastdepCC\" was never defined.
- +Usually this means the macro was only invoked conditionally." >&5
- +echo "$as_me: error: conditional \"am__fastdepCC\" was never defined.
- +Usually this means the macro was only invoked conditionally." >&2;}
- + { (exit 1); exit 1; }; }
- +fi
- +
- +: ${CONFIG_STATUS=./config.status}
- +ac_clean_files_save=$ac_clean_files
- +ac_clean_files="$ac_clean_files $CONFIG_STATUS"
- +{ echo "$as_me:$LINENO: creating $CONFIG_STATUS" >&5
- +echo "$as_me: creating $CONFIG_STATUS" >&6;}
- +cat >$CONFIG_STATUS <<_ACEOF
- +#! $SHELL
- +# Generated by $as_me.
- +# Run this file to recreate the current configuration.
- +# Compiler output produced by configure, useful for debugging
- +# configure, is in config.log if it exists.
- +
- +debug=false
- +ac_cs_recheck=false
- +ac_cs_silent=false
- +SHELL=\${CONFIG_SHELL-$SHELL}
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +## --------------------- ##
- +## M4sh Initialization. ##
- +## --------------------- ##
- +
- +# Be Bourne compatible
- +if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
- + emulate sh
- + NULLCMD=:
- + # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which
- + # is contrary to our usage. Disable this feature.
- + alias -g '${1+"$@"}'='"$@"'
- +elif test -n "${BASH_VERSION+set}" && (set -o posix) >/dev/null 2>&1; then
- + set -o posix
- +fi
- +DUALCASE=1; export DUALCASE # for MKS sh
- +
- +# Support unset when possible.
- +if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
- + as_unset=unset
- +else
- + as_unset=false
- +fi
- +
- +
- +# Work around bugs in pre-3.0 UWIN ksh.
- +$as_unset ENV MAIL MAILPATH
- +PS1='$ '
- +PS2='> '
- +PS4='+ '
- +
- +# NLS nuisances.
- +for as_var in \
- + LANG LANGUAGE LC_ADDRESS LC_ALL LC_COLLATE LC_CTYPE LC_IDENTIFICATION \
- + LC_MEASUREMENT LC_MESSAGES LC_MONETARY LC_NAME LC_NUMERIC LC_PAPER \
- + LC_TELEPHONE LC_TIME
- +do
- + if (set +x; test -z "`(eval $as_var=C; export $as_var) 2>&1`"); then
- + eval $as_var=C; export $as_var
- + else
- + $as_unset $as_var
- + fi
- +done
- +
- +# Required to use basename.
- +if expr a : '\(a\)' >/dev/null 2>&1; then
- + as_expr=expr
- +else
- + as_expr=false
- +fi
- +
- +if (basename /) >/dev/null 2>&1 && test "X`basename / 2>&1`" = "X/"; then
- + as_basename=basename
- +else
- + as_basename=false
- +fi
- +
- +
- +# Name of the executable.
- +as_me=`$as_basename "$0" ||
- +$as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \
- + X"$0" : 'X\(//\)$' \| \
- + X"$0" : 'X\(/\)$' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X/"$0" |
- + sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/; q; }
- + /^X\/\(\/\/\)$/{ s//\1/; q; }
- + /^X\/\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- +
- +
- +# PATH needs CR, and LINENO needs CR and PATH.
- +# Avoid depending upon Character Ranges.
- +as_cr_letters='abcdefghijklmnopqrstuvwxyz'
- +as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ'
- +as_cr_Letters=$as_cr_letters$as_cr_LETTERS
- +as_cr_digits='0123456789'
- +as_cr_alnum=$as_cr_Letters$as_cr_digits
- +
- +# The user is always right.
- +if test "${PATH_SEPARATOR+set}" != set; then
- + echo "#! /bin/sh" >conf$$.sh
- + echo "exit 0" >>conf$$.sh
- + chmod +x conf$$.sh
- + if (PATH="/nonexistent;."; conf$$.sh) >/dev/null 2>&1; then
- + PATH_SEPARATOR=';'
- + else
- + PATH_SEPARATOR=:
- + fi
- + rm -f conf$$.sh
- +fi
- +
- +
- + as_lineno_1=$LINENO
- + as_lineno_2=$LINENO
- + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null`
- + test "x$as_lineno_1" != "x$as_lineno_2" &&
- + test "x$as_lineno_3" = "x$as_lineno_2" || {
- + # Find who we are. Look in the path if we contain no path at all
- + # relative or not.
- + case $0 in
- + *[\\/]* ) as_myself=$0 ;;
- + *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in $PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + test -r "$as_dir/$0" && as_myself=$as_dir/$0 && break
- +done
- +
- + ;;
- + esac
- + # We did not find ourselves, most probably we were run as `sh COMMAND'
- + # in which case we are not to be found in the path.
- + if test "x$as_myself" = x; then
- + as_myself=$0
- + fi
- + if test ! -f "$as_myself"; then
- + { { echo "$as_me:$LINENO: error: cannot find myself; rerun with an absolute path" >&5
- +echo "$as_me: error: cannot find myself; rerun with an absolute path" >&2;}
- + { (exit 1); exit 1; }; }
- + fi
- + case $CONFIG_SHELL in
- + '')
- + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
- +for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH
- +do
- + IFS=$as_save_IFS
- + test -z "$as_dir" && as_dir=.
- + for as_base in sh bash ksh sh5; do
- + case $as_dir in
- + /*)
- + if ("$as_dir/$as_base" -c '
- + as_lineno_1=$LINENO
- + as_lineno_2=$LINENO
- + as_lineno_3=`(expr $as_lineno_1 + 1) 2>/dev/null`
- + test "x$as_lineno_1" != "x$as_lineno_2" &&
- + test "x$as_lineno_3" = "x$as_lineno_2" ') 2>/dev/null; then
- + $as_unset BASH_ENV || test "${BASH_ENV+set}" != set || { BASH_ENV=; export BASH_ENV; }
- + $as_unset ENV || test "${ENV+set}" != set || { ENV=; export ENV; }
- + CONFIG_SHELL=$as_dir/$as_base
- + export CONFIG_SHELL
- + exec "$CONFIG_SHELL" "$0" ${1+"$@"}
- + fi;;
- + esac
- + done
- +done
- +;;
- + esac
- +
- + # Create $as_me.lineno as a copy of $as_myself, but with $LINENO
- + # uniformly replaced by the line number. The first 'sed' inserts a
- + # line-number line before each line; the second 'sed' does the real
- + # work. The second script uses 'N' to pair each line-number line
- + # with the numbered line, and appends trailing '-' during
- + # substitution so that $LINENO is not a special case at line end.
- + # (Raja R Harinath suggested sed '=', and Paul Eggert wrote the
- + # second 'sed' script. Blame Lee E. McMahon for sed's syntax. :-)
- + sed '=' <$as_myself |
- + sed '
- + N
- + s,$,-,
- + : loop
- + s,^\(['$as_cr_digits']*\)\(.*\)[$]LINENO\([^'$as_cr_alnum'_]\),\1\2\1\3,
- + t loop
- + s,-$,,
- + s,^['$as_cr_digits']*\n,,
- + ' >$as_me.lineno &&
- + chmod +x $as_me.lineno ||
- + { { echo "$as_me:$LINENO: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&5
- +echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2;}
- + { (exit 1); exit 1; }; }
- +
- + # Don't try to exec as it changes $[0], causing all sort of problems
- + # (the dirname of $[0] is not the place where we might find the
- + # original and so on. Autoconf is especially sensible to this).
- + . ./$as_me.lineno
- + # Exit status is that of the last command.
- + exit
- +}
- +
- +
- +case `echo "testing\c"; echo 1,2,3`,`echo -n testing; echo 1,2,3` in
- + *c*,-n*) ECHO_N= ECHO_C='
- +' ECHO_T=' ' ;;
- + *c*,* ) ECHO_N=-n ECHO_C= ECHO_T= ;;
- + *) ECHO_N= ECHO_C='\c' ECHO_T= ;;
- +esac
- +
- +if expr a : '\(a\)' >/dev/null 2>&1; then
- + as_expr=expr
- +else
- + as_expr=false
- +fi
- +
- +rm -f conf$$ conf$$.exe conf$$.file
- +echo >conf$$.file
- +if ln -s conf$$.file conf$$ 2>/dev/null; then
- + # We could just check for DJGPP; but this test a) works b) is more generic
- + # and c) will remain valid once DJGPP supports symlinks (DJGPP 2.04).
- + if test -f conf$$.exe; then
- + # Don't use ln at all; we don't have any links
- + as_ln_s='cp -p'
- + else
- + as_ln_s='ln -s'
- + fi
- +elif ln conf$$.file conf$$ 2>/dev/null; then
- + as_ln_s=ln
- +else
- + as_ln_s='cp -p'
- +fi
- +rm -f conf$$ conf$$.exe conf$$.file
- +
- +if mkdir -p . 2>/dev/null; then
- + as_mkdir_p=:
- +else
- + test -d ./-p && rmdir ./-p
- + as_mkdir_p=false
- +fi
- +
- +as_executable_p="test -f"
- +
- +# Sed expression to map a string onto a valid CPP name.
- +as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'"
- +
- +# Sed expression to map a string onto a valid variable name.
- +as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'"
- +
- +
- +# IFS
- +# We need space, tab and new line, in precisely that order.
- +as_nl='
- +'
- +IFS=" $as_nl"
- +
- +# CDPATH.
- +$as_unset CDPATH
- +
- +exec 6>&1
- +
- +# Open the log real soon, to keep \$[0] and so on meaningful, and to
- +# report actual input values of CONFIG_FILES etc. instead of their
- +# values after options handling. Logging --version etc. is OK.
- +exec 5>>config.log
- +{
- + echo
- + sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX
- +## Running $as_me. ##
- +_ASBOX
- +} >&5
- +cat >&5 <<_CSEOF
- +
- +This file was extended by $as_me, which was
- +generated by GNU Autoconf 2.59. Invocation command line was
- +
- + CONFIG_FILES = $CONFIG_FILES
- + CONFIG_HEADERS = $CONFIG_HEADERS
- + CONFIG_LINKS = $CONFIG_LINKS
- + CONFIG_COMMANDS = $CONFIG_COMMANDS
- + $ $0 $@
- +
- +_CSEOF
- +echo "on `(hostname || uname -n) 2>/dev/null | sed 1q`" >&5
- +echo >&5
- +_ACEOF
- +
- +# Files that config.status was made for.
- +if test -n "$ac_config_files"; then
- + echo "config_files=\"$ac_config_files\"" >>$CONFIG_STATUS
- +fi
- +
- +if test -n "$ac_config_headers"; then
- + echo "config_headers=\"$ac_config_headers\"" >>$CONFIG_STATUS
- +fi
- +
- +if test -n "$ac_config_links"; then
- + echo "config_links=\"$ac_config_links\"" >>$CONFIG_STATUS
- +fi
- +
- +if test -n "$ac_config_commands"; then
- + echo "config_commands=\"$ac_config_commands\"" >>$CONFIG_STATUS
- +fi
- +
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +
- +ac_cs_usage="\
- +\`$as_me' instantiates files from templates according to the
- +current configuration.
- +
- +Usage: $0 [OPTIONS] [FILE]...
- +
- + -h, --help print this help, then exit
- + -V, --version print version number, then exit
- + -q, --quiet do not print progress messages
- + -d, --debug don't remove temporary files
- + --recheck update $as_me by reconfiguring in the same conditions
- + --file=FILE[:TEMPLATE]
- + instantiate the configuration file FILE
- +
- +Configuration files:
- +$config_files
- +
- +Configuration commands:
- +$config_commands
- +
- +Report bugs to <bug-autoconf@gnu.org>."
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<_ACEOF
- +ac_cs_version="\\
- +config.status
- +configured by $0, generated by GNU Autoconf 2.59,
- + with options \\"`echo "$ac_configure_args" | sed 's/[\\""\`\$]/\\\\&/g'`\\"
- +
- +Copyright (C) 2003 Free Software Foundation, Inc.
- +This config.status script is free software; the Free Software Foundation
- +gives unlimited permission to copy, distribute and modify it."
- +srcdir=$srcdir
- +INSTALL="$INSTALL"
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +# If no file are specified by the user, then we need to provide default
- +# value. By we need to know if files were specified by the user.
- +ac_need_defaults=:
- +while test $# != 0
- +do
- + case $1 in
- + --*=*)
- + ac_option=`expr "x$1" : 'x\([^=]*\)='`
- + ac_optarg=`expr "x$1" : 'x[^=]*=\(.*\)'`
- + ac_shift=:
- + ;;
- + -*)
- + ac_option=$1
- + ac_optarg=$2
- + ac_shift=shift
- + ;;
- + *) # This is not an option, so the user has probably given explicit
- + # arguments.
- + ac_option=$1
- + ac_need_defaults=false;;
- + esac
- +
- + case $ac_option in
- + # Handling of the options.
- +_ACEOF
- +cat >>$CONFIG_STATUS <<\_ACEOF
- + -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r)
- + ac_cs_recheck=: ;;
- + --version | --vers* | -V )
- + echo "$ac_cs_version"; exit 0 ;;
- + --he | --h)
- + # Conflict between --help and --header
- + { { echo "$as_me:$LINENO: error: ambiguous option: $1
- +Try \`$0 --help' for more information." >&5
- +echo "$as_me: error: ambiguous option: $1
- +Try \`$0 --help' for more information." >&2;}
- + { (exit 1); exit 1; }; };;
- + --help | --hel | -h )
- + echo "$ac_cs_usage"; exit 0 ;;
- + --debug | --d* | -d )
- + debug=: ;;
- + --file | --fil | --fi | --f )
- + $ac_shift
- + CONFIG_FILES="$CONFIG_FILES $ac_optarg"
- + ac_need_defaults=false;;
- + --header | --heade | --head | --hea )
- + $ac_shift
- + CONFIG_HEADERS="$CONFIG_HEADERS $ac_optarg"
- + ac_need_defaults=false;;
- + -q | -quiet | --quiet | --quie | --qui | --qu | --q \
- + | -silent | --silent | --silen | --sile | --sil | --si | --s)
- + ac_cs_silent=: ;;
- +
- + # This is an error.
- + -*) { { echo "$as_me:$LINENO: error: unrecognized option: $1
- +Try \`$0 --help' for more information." >&5
- +echo "$as_me: error: unrecognized option: $1
- +Try \`$0 --help' for more information." >&2;}
- + { (exit 1); exit 1; }; } ;;
- +
- + *) ac_config_targets="$ac_config_targets $1" ;;
- +
- + esac
- + shift
- +done
- +
- +ac_configure_extra_args=
- +
- +if $ac_cs_silent; then
- + exec 6>/dev/null
- + ac_configure_extra_args="$ac_configure_extra_args --silent"
- +fi
- +
- +_ACEOF
- +cat >>$CONFIG_STATUS <<_ACEOF
- +if \$ac_cs_recheck; then
- + echo "running $SHELL $0 " $ac_configure_args \$ac_configure_extra_args " --no-create --no-recursion" >&6
- + exec $SHELL $0 $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion
- +fi
- +
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<_ACEOF
- +#
- +# INIT-COMMANDS section.
- +#
- +
- +AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
- +
- +_ACEOF
- +
- +
- +
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +for ac_config_target in $ac_config_targets
- +do
- + case "$ac_config_target" in
- + # Handling of arguments.
- + "Makefile" ) CONFIG_FILES="$CONFIG_FILES Makefile" ;;
- + "depfiles" ) CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;;
- + *) { { echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5
- +echo "$as_me: error: invalid argument: $ac_config_target" >&2;}
- + { (exit 1); exit 1; }; };;
- + esac
- +done
- +
- +# If the user did not use the arguments to specify the items to instantiate,
- +# then the envvar interface is used. Set only those that are not.
- +# We use the long form for the default assignment because of an extremely
- +# bizarre bug on SunOS 4.1.3.
- +if $ac_need_defaults; then
- + test "${CONFIG_FILES+set}" = set || CONFIG_FILES=$config_files
- + test "${CONFIG_COMMANDS+set}" = set || CONFIG_COMMANDS=$config_commands
- +fi
- +
- +# Have a temporary directory for convenience. Make it in the build tree
- +# simply because there is no reason to put it here, and in addition,
- +# creating and moving files from /tmp can sometimes cause problems.
- +# Create a temporary directory, and hook for its removal unless debugging.
- +$debug ||
- +{
- + trap 'exit_status=$?; rm -rf $tmp && exit $exit_status' 0
- + trap '{ (exit 1); exit 1; }' 1 2 13 15
- +}
- +
- +# Create a (secure) tmp directory for tmp files.
- +
- +{
- + tmp=`(umask 077 && mktemp -d -q "./confstatXXXXXX") 2>/dev/null` &&
- + test -n "$tmp" && test -d "$tmp"
- +} ||
- +{
- + tmp=./confstat$$-$RANDOM
- + (umask 077 && mkdir $tmp)
- +} ||
- +{
- + echo "$me: cannot create a temporary directory in ." >&2
- + { (exit 1); exit 1; }
- +}
- +
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<_ACEOF
- +
- +#
- +# CONFIG_FILES section.
- +#
- +
- +# No need to generate the scripts if there are no CONFIG_FILES.
- +# This happens for instance when ./config.status config.h
- +if test -n "\$CONFIG_FILES"; then
- + # Protect against being on the right side of a sed subst in config.status.
- + sed 's/,@/@@/; s/@,/@@/; s/,;t t\$/@;t t/; /@;t t\$/s/[\\\\&,]/\\\\&/g;
- + s/@@/,@/; s/@@/@,/; s/@;t t\$/,;t t/' >\$tmp/subs.sed <<\\CEOF
- +s,@SHELL@,$SHELL,;t t
- +s,@PATH_SEPARATOR@,$PATH_SEPARATOR,;t t
- +s,@PACKAGE_NAME@,$PACKAGE_NAME,;t t
- +s,@PACKAGE_TARNAME@,$PACKAGE_TARNAME,;t t
- +s,@PACKAGE_VERSION@,$PACKAGE_VERSION,;t t
- +s,@PACKAGE_STRING@,$PACKAGE_STRING,;t t
- +s,@PACKAGE_BUGREPORT@,$PACKAGE_BUGREPORT,;t t
- +s,@exec_prefix@,$exec_prefix,;t t
- +s,@prefix@,$prefix,;t t
- +s,@program_transform_name@,$program_transform_name,;t t
- +s,@bindir@,$bindir,;t t
- +s,@sbindir@,$sbindir,;t t
- +s,@libexecdir@,$libexecdir,;t t
- +s,@datadir@,$datadir,;t t
- +s,@sysconfdir@,$sysconfdir,;t t
- +s,@sharedstatedir@,$sharedstatedir,;t t
- +s,@localstatedir@,$localstatedir,;t t
- +s,@libdir@,$libdir,;t t
- +s,@includedir@,$includedir,;t t
- +s,@oldincludedir@,$oldincludedir,;t t
- +s,@infodir@,$infodir,;t t
- +s,@mandir@,$mandir,;t t
- +s,@build_alias@,$build_alias,;t t
- +s,@host_alias@,$host_alias,;t t
- +s,@target_alias@,$target_alias,;t t
- +s,@DEFS@,$DEFS,;t t
- +s,@ECHO_C@,$ECHO_C,;t t
- +s,@ECHO_N@,$ECHO_N,;t t
- +s,@ECHO_T@,$ECHO_T,;t t
- +s,@LIBS@,$LIBS,;t t
- +s,@INSTALL_PROGRAM@,$INSTALL_PROGRAM,;t t
- +s,@INSTALL_SCRIPT@,$INSTALL_SCRIPT,;t t
- +s,@INSTALL_DATA@,$INSTALL_DATA,;t t
- +s,@CYGPATH_W@,$CYGPATH_W,;t t
- +s,@PACKAGE@,$PACKAGE,;t t
- +s,@VERSION@,$VERSION,;t t
- +s,@ACLOCAL@,$ACLOCAL,;t t
- +s,@AUTOCONF@,$AUTOCONF,;t t
- +s,@AUTOMAKE@,$AUTOMAKE,;t t
- +s,@AUTOHEADER@,$AUTOHEADER,;t t
- +s,@MAKEINFO@,$MAKEINFO,;t t
- +s,@AMTAR@,$AMTAR,;t t
- +s,@install_sh@,$install_sh,;t t
- +s,@STRIP@,$STRIP,;t t
- +s,@ac_ct_STRIP@,$ac_ct_STRIP,;t t
- +s,@INSTALL_STRIP_PROGRAM@,$INSTALL_STRIP_PROGRAM,;t t
- +s,@mkdir_p@,$mkdir_p,;t t
- +s,@AWK@,$AWK,;t t
- +s,@SET_MAKE@,$SET_MAKE,;t t
- +s,@am__leading_dot@,$am__leading_dot,;t t
- +s,@CC@,$CC,;t t
- +s,@CFLAGS@,$CFLAGS,;t t
- +s,@LDFLAGS@,$LDFLAGS,;t t
- +s,@CPPFLAGS@,$CPPFLAGS,;t t
- +s,@ac_ct_CC@,$ac_ct_CC,;t t
- +s,@EXEEXT@,$EXEEXT,;t t
- +s,@OBJEXT@,$OBJEXT,;t t
- +s,@DEPDIR@,$DEPDIR,;t t
- +s,@am__include@,$am__include,;t t
- +s,@am__quote@,$am__quote,;t t
- +s,@AMDEP_TRUE@,$AMDEP_TRUE,;t t
- +s,@AMDEP_FALSE@,$AMDEP_FALSE,;t t
- +s,@AMDEPBACKSLASH@,$AMDEPBACKSLASH,;t t
- +s,@CCDEPMODE@,$CCDEPMODE,;t t
- +s,@am__fastdepCC_TRUE@,$am__fastdepCC_TRUE,;t t
- +s,@am__fastdepCC_FALSE@,$am__fastdepCC_FALSE,;t t
- +s,@LIBOBJS@,$LIBOBJS,;t t
- +s,@LTLIBOBJS@,$LTLIBOBJS,;t t
- +CEOF
- +
- +_ACEOF
- +
- + cat >>$CONFIG_STATUS <<\_ACEOF
- + # Split the substitutions into bite-sized pieces for seds with
- + # small command number limits, like on Digital OSF/1 and HP-UX.
- + ac_max_sed_lines=48
- + ac_sed_frag=1 # Number of current file.
- + ac_beg=1 # First line for current file.
- + ac_end=$ac_max_sed_lines # Line after last line for current file.
- + ac_more_lines=:
- + ac_sed_cmds=
- + while $ac_more_lines; do
- + if test $ac_beg -gt 1; then
- + sed "1,${ac_beg}d; ${ac_end}q" $tmp/subs.sed >$tmp/subs.frag
- + else
- + sed "${ac_end}q" $tmp/subs.sed >$tmp/subs.frag
- + fi
- + if test ! -s $tmp/subs.frag; then
- + ac_more_lines=false
- + else
- + # The purpose of the label and of the branching condition is to
- + # speed up the sed processing (if there are no `@' at all, there
- + # is no need to browse any of the substitutions).
- + # These are the two extra sed commands mentioned above.
- + (echo ':t
- + /@[a-zA-Z_][a-zA-Z_0-9]*@/!b' && cat $tmp/subs.frag) >$tmp/subs-$ac_sed_frag.sed
- + if test -z "$ac_sed_cmds"; then
- + ac_sed_cmds="sed -f $tmp/subs-$ac_sed_frag.sed"
- + else
- + ac_sed_cmds="$ac_sed_cmds | sed -f $tmp/subs-$ac_sed_frag.sed"
- + fi
- + ac_sed_frag=`expr $ac_sed_frag + 1`
- + ac_beg=$ac_end
- + ac_end=`expr $ac_end + $ac_max_sed_lines`
- + fi
- + done
- + if test -z "$ac_sed_cmds"; then
- + ac_sed_cmds=cat
- + fi
- +fi # test -n "$CONFIG_FILES"
- +
- +_ACEOF
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +for ac_file in : $CONFIG_FILES; do test "x$ac_file" = x: && continue
- + # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in".
- + case $ac_file in
- + - | *:- | *:-:* ) # input from stdin
- + cat >$tmp/stdin
- + ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'`
- + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;;
- + *:* ) ac_file_in=`echo "$ac_file" | sed 's,[^:]*:,,'`
- + ac_file=`echo "$ac_file" | sed 's,:.*,,'` ;;
- + * ) ac_file_in=$ac_file.in ;;
- + esac
- +
- + # Compute @srcdir@, @top_srcdir@, and @INSTALL@ for subdirectories.
- + ac_dir=`(dirname "$ac_file") 2>/dev/null ||
- +$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$ac_file" : 'X\(//\)[^/]' \| \
- + X"$ac_file" : 'X\(//\)$' \| \
- + X"$ac_file" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$ac_file" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + { if $as_mkdir_p; then
- + mkdir -p "$ac_dir"
- + else
- + as_dir="$ac_dir"
- + as_dirs=
- + while test ! -d "$as_dir"; do
- + as_dirs="$as_dir $as_dirs"
- + as_dir=`(dirname "$as_dir") 2>/dev/null ||
- +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$as_dir" : 'X\(//\)[^/]' \| \
- + X"$as_dir" : 'X\(//\)$' \| \
- + X"$as_dir" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$as_dir" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + done
- + test ! -n "$as_dirs" || mkdir $as_dirs
- + fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5
- +echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;}
- + { (exit 1); exit 1; }; }; }
- +
- + ac_builddir=.
- +
- +if test "$ac_dir" != .; then
- + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'`
- + # A "../" for each directory in $ac_dir_suffix.
- + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'`
- +else
- + ac_dir_suffix= ac_top_builddir=
- +fi
- +
- +case $srcdir in
- + .) # No --srcdir option. We are building in place.
- + ac_srcdir=.
- + if test -z "$ac_top_builddir"; then
- + ac_top_srcdir=.
- + else
- + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'`
- + fi ;;
- + [\\/]* | ?:[\\/]* ) # Absolute path.
- + ac_srcdir=$srcdir$ac_dir_suffix;
- + ac_top_srcdir=$srcdir ;;
- + *) # Relative path.
- + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix
- + ac_top_srcdir=$ac_top_builddir$srcdir ;;
- +esac
- +
- +# Do not use `cd foo && pwd` to compute absolute paths, because
- +# the directories may not exist.
- +case `pwd` in
- +.) ac_abs_builddir="$ac_dir";;
- +*)
- + case "$ac_dir" in
- + .) ac_abs_builddir=`pwd`;;
- + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";;
- + *) ac_abs_builddir=`pwd`/"$ac_dir";;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_builddir=${ac_top_builddir}.;;
- +*)
- + case ${ac_top_builddir}. in
- + .) ac_abs_top_builddir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;;
- + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_srcdir=$ac_srcdir;;
- +*)
- + case $ac_srcdir in
- + .) ac_abs_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;;
- + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_srcdir=$ac_top_srcdir;;
- +*)
- + case $ac_top_srcdir in
- + .) ac_abs_top_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;;
- + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;;
- + esac;;
- +esac
- +
- +
- + case $INSTALL in
- + [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;;
- + *) ac_INSTALL=$ac_top_builddir$INSTALL ;;
- + esac
- +
- + # Let's still pretend it is `configure' which instantiates (i.e., don't
- + # use $as_me), people would be surprised to read:
- + # /* config.h. Generated by config.status. */
- + if test x"$ac_file" = x-; then
- + configure_input=
- + else
- + configure_input="$ac_file. "
- + fi
- + configure_input=$configure_input"Generated from `echo $ac_file_in |
- + sed 's,.*/,,'` by configure."
- +
- + # First look for the input files in the build tree, otherwise in the
- + # src tree.
- + ac_file_inputs=`IFS=:
- + for f in $ac_file_in; do
- + case $f in
- + -) echo $tmp/stdin ;;
- + [\\/$]*)
- + # Absolute (can't be DOS-style, as IFS=:)
- + test -f "$f" || { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5
- +echo "$as_me: error: cannot find input file: $f" >&2;}
- + { (exit 1); exit 1; }; }
- + echo "$f";;
- + *) # Relative
- + if test -f "$f"; then
- + # Build tree
- + echo "$f"
- + elif test -f "$srcdir/$f"; then
- + # Source tree
- + echo "$srcdir/$f"
- + else
- + # /dev/null tree
- + { { echo "$as_me:$LINENO: error: cannot find input file: $f" >&5
- +echo "$as_me: error: cannot find input file: $f" >&2;}
- + { (exit 1); exit 1; }; }
- + fi;;
- + esac
- + done` || { (exit 1); exit 1; }
- +
- + if test x"$ac_file" != x-; then
- + { echo "$as_me:$LINENO: creating $ac_file" >&5
- +echo "$as_me: creating $ac_file" >&6;}
- + rm -f "$ac_file"
- + fi
- +_ACEOF
- +cat >>$CONFIG_STATUS <<_ACEOF
- + sed "$ac_vpsub
- +$extrasub
- +_ACEOF
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +:t
- +/@[a-zA-Z_][a-zA-Z_0-9]*@/!b
- +s,@configure_input@,$configure_input,;t t
- +s,@srcdir@,$ac_srcdir,;t t
- +s,@abs_srcdir@,$ac_abs_srcdir,;t t
- +s,@top_srcdir@,$ac_top_srcdir,;t t
- +s,@abs_top_srcdir@,$ac_abs_top_srcdir,;t t
- +s,@builddir@,$ac_builddir,;t t
- +s,@abs_builddir@,$ac_abs_builddir,;t t
- +s,@top_builddir@,$ac_top_builddir,;t t
- +s,@abs_top_builddir@,$ac_abs_top_builddir,;t t
- +s,@INSTALL@,$ac_INSTALL,;t t
- +" $ac_file_inputs | (eval "$ac_sed_cmds") >$tmp/out
- + rm -f $tmp/stdin
- + if test x"$ac_file" != x-; then
- + mv $tmp/out $ac_file
- + else
- + cat $tmp/out
- + rm -f $tmp/out
- + fi
- +
- +done
- +_ACEOF
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +
- +#
- +# CONFIG_COMMANDS section.
- +#
- +for ac_file in : $CONFIG_COMMANDS; do test "x$ac_file" = x: && continue
- + ac_dest=`echo "$ac_file" | sed 's,:.*,,'`
- + ac_source=`echo "$ac_file" | sed 's,[^:]*:,,'`
- + ac_dir=`(dirname "$ac_dest") 2>/dev/null ||
- +$as_expr X"$ac_dest" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$ac_dest" : 'X\(//\)[^/]' \| \
- + X"$ac_dest" : 'X\(//\)$' \| \
- + X"$ac_dest" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$ac_dest" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + { if $as_mkdir_p; then
- + mkdir -p "$ac_dir"
- + else
- + as_dir="$ac_dir"
- + as_dirs=
- + while test ! -d "$as_dir"; do
- + as_dirs="$as_dir $as_dirs"
- + as_dir=`(dirname "$as_dir") 2>/dev/null ||
- +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$as_dir" : 'X\(//\)[^/]' \| \
- + X"$as_dir" : 'X\(//\)$' \| \
- + X"$as_dir" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$as_dir" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + done
- + test ! -n "$as_dirs" || mkdir $as_dirs
- + fi || { { echo "$as_me:$LINENO: error: cannot create directory \"$ac_dir\"" >&5
- +echo "$as_me: error: cannot create directory \"$ac_dir\"" >&2;}
- + { (exit 1); exit 1; }; }; }
- +
- + ac_builddir=.
- +
- +if test "$ac_dir" != .; then
- + ac_dir_suffix=/`echo "$ac_dir" | sed 's,^\.[\\/],,'`
- + # A "../" for each directory in $ac_dir_suffix.
- + ac_top_builddir=`echo "$ac_dir_suffix" | sed 's,/[^\\/]*,../,g'`
- +else
- + ac_dir_suffix= ac_top_builddir=
- +fi
- +
- +case $srcdir in
- + .) # No --srcdir option. We are building in place.
- + ac_srcdir=.
- + if test -z "$ac_top_builddir"; then
- + ac_top_srcdir=.
- + else
- + ac_top_srcdir=`echo $ac_top_builddir | sed 's,/$,,'`
- + fi ;;
- + [\\/]* | ?:[\\/]* ) # Absolute path.
- + ac_srcdir=$srcdir$ac_dir_suffix;
- + ac_top_srcdir=$srcdir ;;
- + *) # Relative path.
- + ac_srcdir=$ac_top_builddir$srcdir$ac_dir_suffix
- + ac_top_srcdir=$ac_top_builddir$srcdir ;;
- +esac
- +
- +# Do not use `cd foo && pwd` to compute absolute paths, because
- +# the directories may not exist.
- +case `pwd` in
- +.) ac_abs_builddir="$ac_dir";;
- +*)
- + case "$ac_dir" in
- + .) ac_abs_builddir=`pwd`;;
- + [\\/]* | ?:[\\/]* ) ac_abs_builddir="$ac_dir";;
- + *) ac_abs_builddir=`pwd`/"$ac_dir";;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_builddir=${ac_top_builddir}.;;
- +*)
- + case ${ac_top_builddir}. in
- + .) ac_abs_top_builddir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_builddir=${ac_top_builddir}.;;
- + *) ac_abs_top_builddir=$ac_abs_builddir/${ac_top_builddir}.;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_srcdir=$ac_srcdir;;
- +*)
- + case $ac_srcdir in
- + .) ac_abs_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_srcdir=$ac_srcdir;;
- + *) ac_abs_srcdir=$ac_abs_builddir/$ac_srcdir;;
- + esac;;
- +esac
- +case $ac_abs_builddir in
- +.) ac_abs_top_srcdir=$ac_top_srcdir;;
- +*)
- + case $ac_top_srcdir in
- + .) ac_abs_top_srcdir=$ac_abs_builddir;;
- + [\\/]* | ?:[\\/]* ) ac_abs_top_srcdir=$ac_top_srcdir;;
- + *) ac_abs_top_srcdir=$ac_abs_builddir/$ac_top_srcdir;;
- + esac;;
- +esac
- +
- +
- + { echo "$as_me:$LINENO: executing $ac_dest commands" >&5
- +echo "$as_me: executing $ac_dest commands" >&6;}
- + case $ac_dest in
- + depfiles ) test x"$AMDEP_TRUE" != x"" || for mf in $CONFIG_FILES; do
- + # Strip MF so we end up with the name of the file.
- + mf=`echo "$mf" | sed -e 's/:.*$//'`
- + # Check whether this is an Automake generated Makefile or not.
- + # We used to match only the files named `Makefile.in', but
- + # some people rename them; so instead we look at the file content.
- + # Grep'ing the first line is not enough: some people post-process
- + # each Makefile.in and add a new line on top of each file to say so.
- + # So let's grep whole file.
- + if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then
- + dirpart=`(dirname "$mf") 2>/dev/null ||
- +$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$mf" : 'X\(//\)[^/]' \| \
- + X"$mf" : 'X\(//\)$' \| \
- + X"$mf" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$mf" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + else
- + continue
- + fi
- + grep '^DEP_FILES *= *[^ #]' < "$mf" > /dev/null || continue
- + # Extract the definition of DEP_FILES from the Makefile without
- + # running `make'.
- + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
- + test -z "$DEPDIR" && continue
- + # When using ansi2knr, U may be empty or an underscore; expand it
- + U=`sed -n 's/^U = //p' < "$mf"`
- + test -d "$dirpart/$DEPDIR" || mkdir "$dirpart/$DEPDIR"
- + # We invoke sed twice because it is the simplest approach to
- + # changing $(DEPDIR) to its actual value in the expansion.
- + for file in `sed -n '
- + /^DEP_FILES = .*\\\\$/ {
- + s/^DEP_FILES = //
- + :loop
- + s/\\\\$//
- + p
- + n
- + /\\\\$/ b loop
- + p
- + }
- + /^DEP_FILES = / s/^DEP_FILES = //p' < "$mf" | \
- + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
- + # Make sure the directory exists.
- + test -f "$dirpart/$file" && continue
- + fdir=`(dirname "$file") 2>/dev/null ||
- +$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$file" : 'X\(//\)[^/]' \| \
- + X"$file" : 'X\(//\)$' \| \
- + X"$file" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$file" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + { if $as_mkdir_p; then
- + mkdir -p $dirpart/$fdir
- + else
- + as_dir=$dirpart/$fdir
- + as_dirs=
- + while test ! -d "$as_dir"; do
- + as_dirs="$as_dir $as_dirs"
- + as_dir=`(dirname "$as_dir") 2>/dev/null ||
- +$as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- + X"$as_dir" : 'X\(//\)[^/]' \| \
- + X"$as_dir" : 'X\(//\)$' \| \
- + X"$as_dir" : 'X\(/\)' \| \
- + . : '\(.\)' 2>/dev/null ||
- +echo X"$as_dir" |
- + sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/; q; }
- + /^X\(\/\/\)[^/].*/{ s//\1/; q; }
- + /^X\(\/\/\)$/{ s//\1/; q; }
- + /^X\(\/\).*/{ s//\1/; q; }
- + s/.*/./; q'`
- + done
- + test ! -n "$as_dirs" || mkdir $as_dirs
- + fi || { { echo "$as_me:$LINENO: error: cannot create directory $dirpart/$fdir" >&5
- +echo "$as_me: error: cannot create directory $dirpart/$fdir" >&2;}
- + { (exit 1); exit 1; }; }; }
- +
- + # echo "creating $dirpart/$file"
- + echo '# dummy' > "$dirpart/$file"
- + done
- +done
- + ;;
- + esac
- +done
- +_ACEOF
- +
- +cat >>$CONFIG_STATUS <<\_ACEOF
- +
- +{ (exit 0); exit 0; }
- +_ACEOF
- +chmod +x $CONFIG_STATUS
- +ac_clean_files=$ac_clean_files_save
- +
- +
- +# configure is writing to config.log, and then calls config.status.
- +# config.status does its own redirection, appending to config.log.
- +# Unfortunately, on DOS this fails, as config.log is still kept open
- +# by configure, so config.status won't be able to write to it; its
- +# output is simply discarded. So we exec the FD to /dev/null,
- +# effectively closing config.log, so it can be properly (re)opened and
- +# appended to by config.status. When coming back to configure, we
- +# need to make the FD available again.
- +if test "$no_create" != yes; then
- + ac_cs_success=:
- + ac_config_status_args=
- + test "$silent" = yes &&
- + ac_config_status_args="$ac_config_status_args --quiet"
- + exec 5>/dev/null
- + $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false
- + exec 5>>config.log
- + # Use ||, not &&, to avoid exiting from the if with $? = 1, which
- + # would make configure fail if this is the last instruction.
- + $ac_cs_success || { (exit 1); exit 1; }
- +fi
- +
- diff --exclude CVS -urN genext2fs-1.3.orig/configure.in genext2fs/configure.in
- --- genext2fs-1.3.orig/configure.in 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/configure.in 2001-05-02 12:20:05.000000000 -0600
- @@ -0,0 +1,5 @@
- +AC_INIT(genext2fs.c)
- +AM_INIT_AUTOMAKE(genext2fs,1.3)
- +AC_PROG_CC
- +AC_PROG_INSTALL
- +AC_OUTPUT(Makefile)
- diff --exclude CVS -urN genext2fs-1.3.orig/debian/changelog genext2fs/debian/changelog
- --- genext2fs-1.3.orig/debian/changelog 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/debian/changelog 2001-07-26 22:41:25.000000000 -0600
- @@ -0,0 +1,9 @@
- +genext2fs (1.3-1) unstable; urgency=low
- +
- + * Initial Release. (closes: #105263)
- +
- + -- David Kimdon <dwhedon@debian.org> Sat, 14 Jul 2001 13:24:49 -0700
- +
- +Local variables:
- +mode: debian-changelog
- +End:
- diff --exclude CVS -urN genext2fs-1.3.orig/debian/control genext2fs/debian/control
- --- genext2fs-1.3.orig/debian/control 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/debian/control 2001-07-16 18:01:00.000000000 -0600
- @@ -0,0 +1,19 @@
- +Source: genext2fs
- +Section: admin
- +Priority: optional
- +Maintainer: David Kimdon <dwhedon@debian.org>
- +Build-Depends: debhelper (>> 3.0.0)
- +Standards-Version: 3.5.2
- +
- +Package: genext2fs
- +Architecture: any
- +Depends: ${shlibs:Depends}
- +Description: ext2 filesystem generator for embedded systems
- + `genext2fs' is meant to generate an ext2 filesystem
- + as a normal (non-root) user. It doesn't require you to mount
- + the image file to copy files on it. It doesn't even require
- + you to be the superuser to make device nodes.
- + .
- + Warning ! `genext2fs' has been designed for embedded
- + systems. As such, it will generate a filesystem for single-user
- + usage: all files/directories/etc... will belong to UID/GID 0
- diff --exclude CVS -urN genext2fs-1.3.orig/debian/copyright genext2fs/debian/copyright
- --- genext2fs-1.3.orig/debian/copyright 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/debian/copyright 2001-07-16 18:01:00.000000000 -0600
- @@ -0,0 +1,15 @@
- +This package was debianized by David Kimdon <dwhedon@debian.org> on
- +Sat, 14 Jul 2001 13:24:49 -0700.
- +
- +It was downloaded from http://freshmeat.net/projects/genext2fs/
- +Upstream Author(s): Xavier Bestel <xbestel@aplio.fr>
- +
- +Copyright (C) 2000 Xavier Bestel <xavier.bestel@free.fr>
- +
- +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; version
- +2 of the License.
- +
- +On Debian systems, the complete text of the GNU General Public
- +License can be found in /usr/share/common-licenses/GPL file.
- diff --exclude CVS -urN genext2fs-1.3.orig/debian/rules genext2fs/debian/rules
- --- genext2fs-1.3.orig/debian/rules 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/debian/rules 2001-07-27 09:08:16.000000000 -0600
- @@ -0,0 +1,69 @@
- +#!/usr/bin/make -f
- +# Sample debian/rules that uses debhelper.
- +# GNU copyright 1997 to 1999 by Joey Hess.
- +
- +# Uncomment this to turn on verbose mode.
- +#export DH_VERBOSE=1
- +
- +# This is the debhelper compatability version to use.
- +export DH_COMPAT=2
- +
- +configure: configure-stamp
- +configure-stamp:
- + dh_testdir
- + # Add here commands to configure the package.
- + # ./configure --prefix=/usr --mandir=/usr/share/man/
- +
- + touch configure-stamp
- +
- +build: configure-stamp build-stamp
- +build-stamp:
- + dh_testdir
- +
- + # Add here commands to compile the package.
- + $(MAKE)
- +
- + touch build-stamp
- +
- +clean:
- + dh_testdir
- + dh_testroot
- + rm -f build-stamp configure-stamp
- +
- + # Add here commands to clean up after the build process.
- + -$(MAKE) clean
- +
- + dh_clean
- +
- +install: build
- + dh_testdir
- + dh_testroot
- + dh_clean -k
- + dh_installdirs
- +
- + # Add here commands to install the package into debian/genext2fs.
- + $(MAKE) install DESTDIR=`pwd`/debian/genext2fs
- +
- +
- +# Build architecture-independent files here.
- +binary-indep: build install
- +# We have nothing to do by default.
- +
- +# Build architecture-dependent files here.
- +binary-arch: build install
- + dh_testdir
- + dh_testroot
- + dh_installdocs
- + dh_installchangelogs
- + dh_link
- + dh_strip
- + dh_compress
- + dh_fixperms
- + dh_installdeb
- + dh_shlibdeps
- + dh_gencontrol
- + dh_md5sums
- + dh_builddeb
- +
- +binary: binary-indep binary-arch
- +.PHONY: build clean binary-indep binary-arch binary install configure
- diff --exclude CVS -urN genext2fs-1.3.orig/depcomp genext2fs/depcomp
- --- genext2fs-1.3.orig/depcomp 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/depcomp 2004-12-27 13:03:47.000000000 -0700
- @@ -0,0 +1,526 @@
- +#! /bin/sh
- +# depcomp - compile a program generating dependencies as side-effects
- +
- +scriptversion=2004-04-25.13
- +
- +# Copyright (C) 1999, 2000, 2003, 2004 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 to the GNU General Public License, if you
- +# distribute this file as part of a program that contains a
- +# configuration script generated by Autoconf, you may include it under
- +# the same distribution terms that you use for the rest of that program.
- +
- +# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
- +
- +case $1 in
- + '')
- + echo "$0: No command. Try \`$0 --help' for more information." 1>&2
- + exit 1;
- + ;;
- + -h | --h*)
- + cat <<\EOF
- +Usage: depcomp [--help] [--version] PROGRAM [ARGS]
- +
- +Run PROGRAMS ARGS to compile a file, generating dependencies
- +as side-effects.
- +
- +Environment variables:
- + depmode Dependency tracking mode.
- + source Source file read by `PROGRAMS ARGS'.
- + object Object file output by `PROGRAMS ARGS'.
- + depfile Dependency file to output.
- + tmpdepfile Temporary file to use when outputing dependencies.
- + libtool Whether libtool is used (yes/no).
- +
- +Report bugs to <bug-automake@gnu.org>.
- +EOF
- + exit 0
- + ;;
- + -v | --v*)
- + echo "depcomp $scriptversion"
- + exit 0
- + ;;
- +esac
- +
- +if test -z "$depmode" || test -z "$source" || test -z "$object"; then
- + echo "depcomp: Variables source, object and depmode must be set" 1>&2
- + exit 1
- +fi
- +# `libtool' can also be set to `yes' or `no'.
- +
- +if test -z "$depfile"; then
- + base=`echo "$object" | sed -e 's,^.*/,,' -e 's,\.\([^.]*\)$,.P\1,'`
- + dir=`echo "$object" | sed 's,/.*$,/,'`
- + if test "$dir" = "$object"; then
- + dir=
- + fi
- + # FIXME: should be _deps on DOS.
- + depfile="$dir.deps/$base"
- +fi
- +
- +tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
- +
- +rm -f "$tmpdepfile"
- +
- +# Some modes work just like other modes, but use different flags. We
- +# parameterize here, but still list the modes in the big case below,
- +# to make depend.m4 easier to write. Note that we *cannot* use a case
- +# here, because this file can only contain one case statement.
- +if test "$depmode" = hp; then
- + # HP compiler uses -M and no extra arg.
- + gccflag=-M
- + depmode=gcc
- +fi
- +
- +if test "$depmode" = dashXmstdout; then
- + # This is just like dashmstdout with a different argument.
- + dashmflag=-xM
- + depmode=dashmstdout
- +fi
- +
- +case "$depmode" in
- +gcc3)
- +## gcc 3 implements dependency tracking that does exactly what
- +## we want. Yay! Note: for some reason libtool 1.4 doesn't like
- +## it if -MD -MP comes after the -MF stuff. Hmm.
- + "$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
- + stat=$?
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile"
- + exit $stat
- + fi
- + mv "$tmpdepfile" "$depfile"
- + ;;
- +
- +gcc)
- +## There are various ways to get dependency output from gcc. Here's
- +## why we pick this rather obscure method:
- +## - Don't want to use -MD because we'd like the dependencies to end
- +## up in a subdir. Having to rename by hand is ugly.
- +## (We might end up doing this anyway to support other compilers.)
- +## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
- +## -MM, not -M (despite what the docs say).
- +## - Using -M directly means running the compiler twice (even worse
- +## than renaming).
- + if test -z "$gccflag"; then
- + gccflag=-MD,
- + fi
- + "$@" -Wp,"$gccflag$tmpdepfile"
- + stat=$?
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile"
- + exit $stat
- + fi
- + rm -f "$depfile"
- + echo "$object : \\" > "$depfile"
- + alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
- +## The second -e expression handles DOS-style file names with drive letters.
- + sed -e 's/^[^:]*: / /' \
- + -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
- +## This next piece of magic avoids the `deleted header file' problem.
- +## The problem is that when a header file which appears in a .P file
- +## is deleted, the dependency causes make to die (because there is
- +## typically no way to rebuild the header). We avoid this by adding
- +## dummy dependencies for each header file. Too bad gcc doesn't do
- +## this for us directly.
- + tr ' ' '
- +' < "$tmpdepfile" |
- +## Some versions of gcc put a space before the `:'. On the theory
- +## that the space means something, we add a space to the output as
- +## well.
- +## Some versions of the HPUX 10.20 sed can't process this invocation
- +## correctly. Breaking it into two sed invocations is a workaround.
- + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- + rm -f "$tmpdepfile"
- + ;;
- +
- +hp)
- + # This case exists only to let depend.m4 do its work. It works by
- + # looking at the text of this script. This case will never be run,
- + # since it is checked for above.
- + exit 1
- + ;;
- +
- +sgi)
- + if test "$libtool" = yes; then
- + "$@" "-Wp,-MDupdate,$tmpdepfile"
- + else
- + "$@" -MDupdate "$tmpdepfile"
- + fi
- + stat=$?
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile"
- + exit $stat
- + fi
- + rm -f "$depfile"
- +
- + if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
- + echo "$object : \\" > "$depfile"
- +
- + # Clip off the initial element (the dependent). Don't try to be
- + # clever and replace this with sed code, as IRIX sed won't handle
- + # lines with more than a fixed number of characters (4096 in
- + # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
- + # the IRIX cc adds comments like `#:fec' to the end of the
- + # dependency line.
- + tr ' ' '
- +' < "$tmpdepfile" \
- + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
- + tr '
- +' ' ' >> $depfile
- + echo >> $depfile
- +
- + # The second pass generates a dummy entry for each header file.
- + tr ' ' '
- +' < "$tmpdepfile" \
- + | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
- + >> $depfile
- + else
- + # The sourcefile does not contain any dependencies, so just
- + # store a dummy comment line, to avoid errors with the Makefile
- + # "include basename.Plo" scheme.
- + echo "#dummy" > "$depfile"
- + fi
- + rm -f "$tmpdepfile"
- + ;;
- +
- +aix)
- + # The C for AIX Compiler uses -M and outputs the dependencies
- + # in a .u file. In older versions, this file always lives in the
- + # current directory. Also, the AIX compiler puts `$object:' at the
- + # start of each line; $object doesn't have directory information.
- + # Version 6 uses the directory in both cases.
- + stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'`
- + tmpdepfile="$stripped.u"
- + if test "$libtool" = yes; then
- + "$@" -Wc,-M
- + else
- + "$@" -M
- + fi
- + stat=$?
- +
- + if test -f "$tmpdepfile"; then :
- + else
- + stripped=`echo "$stripped" | sed 's,^.*/,,'`
- + tmpdepfile="$stripped.u"
- + fi
- +
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile"
- + exit $stat
- + fi
- +
- + if test -f "$tmpdepfile"; then
- + outname="$stripped.o"
- + # Each line is of the form `foo.o: dependent.h'.
- + # Do two passes, one to just change these to
- + # `$object: dependent.h' and one to simply `dependent.h:'.
- + sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
- + sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
- + else
- + # The sourcefile does not contain any dependencies, so just
- + # store a dummy comment line, to avoid errors with the Makefile
- + # "include basename.Plo" scheme.
- + echo "#dummy" > "$depfile"
- + fi
- + rm -f "$tmpdepfile"
- + ;;
- +
- +icc)
- + # Intel's C compiler understands `-MD -MF file'. However on
- + # icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
- + # ICC 7.0 will fill foo.d with something like
- + # foo.o: sub/foo.c
- + # foo.o: sub/foo.h
- + # which is wrong. We want:
- + # sub/foo.o: sub/foo.c
- + # sub/foo.o: sub/foo.h
- + # sub/foo.c:
- + # sub/foo.h:
- + # ICC 7.1 will output
- + # foo.o: sub/foo.c sub/foo.h
- + # and will wrap long lines using \ :
- + # foo.o: sub/foo.c ... \
- + # sub/foo.h ... \
- + # ...
- +
- + "$@" -MD -MF "$tmpdepfile"
- + stat=$?
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile"
- + exit $stat
- + fi
- + rm -f "$depfile"
- + # Each line is of the form `foo.o: dependent.h',
- + # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
- + # Do two passes, one to just change these to
- + # `$object: dependent.h' and one to simply `dependent.h:'.
- + sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
- + # Some versions of the HPUX 10.20 sed can't process this invocation
- + # correctly. Breaking it into two sed invocations is a workaround.
- + sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
- + sed -e 's/$/ :/' >> "$depfile"
- + rm -f "$tmpdepfile"
- + ;;
- +
- +tru64)
- + # The Tru64 compiler uses -MD to generate dependencies as a side
- + # effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
- + # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
- + # dependencies in `foo.d' instead, so we check for that too.
- + # Subdirectories are respected.
- + dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
- + test "x$dir" = "x$object" && dir=
- + base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
- +
- + if test "$libtool" = yes; then
- + # Dependencies are output in .lo.d with libtool 1.4.
- + # They are output in .o.d with libtool 1.5.
- + tmpdepfile1="$dir.libs/$base.lo.d"
- + tmpdepfile2="$dir.libs/$base.o.d"
- + tmpdepfile3="$dir.libs/$base.d"
- + "$@" -Wc,-MD
- + else
- + tmpdepfile1="$dir$base.o.d"
- + tmpdepfile2="$dir$base.d"
- + tmpdepfile3="$dir$base.d"
- + "$@" -MD
- + fi
- +
- + stat=$?
- + if test $stat -eq 0; then :
- + else
- + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
- + exit $stat
- + fi
- +
- + if test -f "$tmpdepfile1"; then
- + tmpdepfile="$tmpdepfile1"
- + elif test -f "$tmpdepfile2"; then
- + tmpdepfile="$tmpdepfile2"
- + else
- + tmpdepfile="$tmpdepfile3"
- + fi
- + if test -f "$tmpdepfile"; then
- + sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
- + # That's a tab and a space in the [].
- + sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
- + else
- + echo "#dummy" > "$depfile"
- + fi
- + rm -f "$tmpdepfile"
- + ;;
- +
- +#nosideeffect)
- + # This comment above is used by automake to tell side-effect
- + # dependency tracking mechanisms from slower ones.
- +
- +dashmstdout)
- + # Important note: in order to support this mode, a compiler *must*
- + # always write the preprocessed file to stdout, regardless of -o.
- + "$@" || exit $?
- +
- + # Remove the call to Libtool.
- + if test "$libtool" = yes; then
- + while test $1 != '--mode=compile'; do
- + shift
- + done
- + shift
- + fi
- +
- + # Remove `-o $object'.
- + IFS=" "
- + for arg
- + do
- + case $arg in
- + -o)
- + shift
- + ;;
- + $object)
- + shift
- + ;;
- + *)
- + set fnord "$@" "$arg"
- + shift # fnord
- + shift # $arg
- + ;;
- + esac
- + done
- +
- + test -z "$dashmflag" && dashmflag=-M
- + # Require at least two characters before searching for `:'
- + # in the target name. This is to cope with DOS-style filenames:
- + # a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
- + "$@" $dashmflag |
- + sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
- + rm -f "$depfile"
- + cat < "$tmpdepfile" > "$depfile"
- + tr ' ' '
- +' < "$tmpdepfile" | \
- +## Some versions of the HPUX 10.20 sed can't process this invocation
- +## correctly. Breaking it into two sed invocations is a workaround.
- + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- + rm -f "$tmpdepfile"
- + ;;
- +
- +dashXmstdout)
- + # This case only exists to satisfy depend.m4. It is never actually
- + # run, as this mode is specially recognized in the preamble.
- + exit 1
- + ;;
- +
- +makedepend)
- + "$@" || exit $?
- + # Remove any Libtool call
- + if test "$libtool" = yes; then
- + while test $1 != '--mode=compile'; do
- + shift
- + done
- + shift
- + fi
- + # X makedepend
- + shift
- + cleared=no
- + for arg in "$@"; do
- + case $cleared in
- + no)
- + set ""; shift
- + cleared=yes ;;
- + esac
- + case "$arg" in
- + -D*|-I*)
- + set fnord "$@" "$arg"; shift ;;
- + # Strip any option that makedepend may not understand. Remove
- + # the object too, otherwise makedepend will parse it as a source file.
- + -*|$object)
- + ;;
- + *)
- + set fnord "$@" "$arg"; shift ;;
- + esac
- + done
- + obj_suffix="`echo $object | sed 's/^.*\././'`"
- + touch "$tmpdepfile"
- + ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
- + rm -f "$depfile"
- + cat < "$tmpdepfile" > "$depfile"
- + sed '1,2d' "$tmpdepfile" | tr ' ' '
- +' | \
- +## Some versions of the HPUX 10.20 sed can't process this invocation
- +## correctly. Breaking it into two sed invocations is a workaround.
- + sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
- + rm -f "$tmpdepfile" "$tmpdepfile".bak
- + ;;
- +
- +cpp)
- + # Important note: in order to support this mode, a compiler *must*
- + # always write the preprocessed file to stdout.
- + "$@" || exit $?
- +
- + # Remove the call to Libtool.
- + if test "$libtool" = yes; then
- + while test $1 != '--mode=compile'; do
- + shift
- + done
- + shift
- + fi
- +
- + # Remove `-o $object'.
- + IFS=" "
- + for arg
- + do
- + case $arg in
- + -o)
- + shift
- + ;;
- + $object)
- + shift
- + ;;
- + *)
- + set fnord "$@" "$arg"
- + shift # fnord
- + shift # $arg
- + ;;
- + esac
- + done
- +
- + "$@" -E |
- + sed -n '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
- + sed '$ s: \\$::' > "$tmpdepfile"
- + rm -f "$depfile"
- + echo "$object : \\" > "$depfile"
- + cat < "$tmpdepfile" >> "$depfile"
- + sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
- + rm -f "$tmpdepfile"
- + ;;
- +
- +msvisualcpp)
- + # Important note: in order to support this mode, a compiler *must*
- + # always write the preprocessed file to stdout, regardless of -o,
- + # because we must use -o when running libtool.
- + "$@" || exit $?
- + IFS=" "
- + for arg
- + do
- + case "$arg" in
- + "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
- + set fnord "$@"
- + shift
- + shift
- + ;;
- + *)
- + set fnord "$@" "$arg"
- + shift
- + shift
- + ;;
- + esac
- + done
- + "$@" -E |
- + sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
- + rm -f "$depfile"
- + echo "$object : \\" > "$depfile"
- + . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
- + echo " " >> "$depfile"
- + . "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
- + rm -f "$tmpdepfile"
- + ;;
- +
- +none)
- + exec "$@"
- + ;;
- +
- +*)
- + echo "Unknown depmode $depmode" 1>&2
- + exit 1
- + ;;
- +esac
- +
- +exit 0
- +
- +# Local Variables:
- +# mode: shell-script
- +# sh-indentation: 2
- +# eval: (add-hook 'write-file-hooks 'time-stamp)
- +# time-stamp-start: "scriptversion="
- +# time-stamp-format: "%:y-%02m-%02d.%02H"
- +# time-stamp-end: "$"
- +# End:
- diff --exclude CVS -urN genext2fs-1.3.orig/dev.txt genext2fs/dev.txt
- --- genext2fs-1.3.orig/dev.txt 2000-09-28 09:03:19.000000000 -0600
- +++ genext2fs/dev.txt 1969-12-31 17:00:00.000000000 -0700
- @@ -1,94 +0,0 @@
- -drwx /dev
- -crw- 10,190 /dev/lcd
- -crw- 10,191 /dev/splc781
- -crw- 4,0 /dev/console
- -crw- 5,64 /dev/cua0
- -crw- 5,65 /dev/cua1
- -crw- 5,66 /dev/cua2
- -crw- 5,70 /dev/cua6
- -crw- 5,71 /dev/cua7
- -crw- 5,72 /dev/cua8
- -crw- 5,73 /dev/cua9
- -crw- 29,0 /dev/fb0
- -crw- 29,32 /dev/fb1
- -crw- 1,2 /dev/kmem
- -crw- 1,1 /dev/mem
- -crw- 1,3 /dev/null
- -crw- 2,2 /dev/ptyp2
- -crw- 2,3 /dev/ptyp3
- -crw- 2,5 /dev/ptyp5
- -crw- 2,4 /dev/ptyp4
- -crw- 10,178 /dev/triokb
- -crw- 2,0 /dev/ptyp0
- -crw- 2,6 /dev/ptyp6
- -crw- 2,7 /dev/ptyp7
- -crw- 2,8 /dev/ptyp8
- -crw- 2,9 /dev/ptyp9
- -crw- 2,10 /dev/ptypa
- -crw- 2,11 /dev/ptypb
- -crw- 2,12 /dev/ptypc
- -crw- 2,13 /dev/ptypd
- -crw- 2,14 /dev/ptype
- -crw- 2,15 /dev/ptypf
- -brw- 1,0 /dev/ram0
- -brw- 1,1 /dev/ram1
- -brw- 1,2 /dev/ram2
- -brw- 1,3 /dev/ram3
- -br-- 31,0 /dev/rom0
- -brw- 31,1 /dev/rom1
- -brw- 31,2 /dev/rom2
- -brw- 31,3 /dev/rom3
- -crw- 5,0 /dev/tty
- -crw- 4,0 /dev/tty0
- -crwx 4,1 /dev/tty1
- -crwx 4,2 /dev/tty2
- -crwx 4,3 /dev/tty3
- -crwx 4,4 /dev/tty4
- -crw- 4,5 /dev/tty5
- -crwx 4,6 /dev/tty6
- -crw- 4,7 /dev/tty7
- -crw- 4,8 /dev/tty8
- -crw- 4,9 /dev/tty9
- -crw- 4,64 /dev/ttyS0
- -crw- 4,65 /dev/ttyS1
- -crw- 4,66 /dev/ttyS2
- -crw- 4,67 /dev/ttyS3
- -crw- 4,68 /dev/ttyS4
- -crw- 4,69 /dev/ttyS5
- -crw- 4,70 /dev/ttyS6
- -crw- 4,71 /dev/ttyS7
- -crw- 4,72 /dev/ttyS8
- -crw- 4,73 /dev/ttyS9
- -crw- 3,0 /dev/ttyp0
- -crw- 3,1 /dev/ttyp1
- -crw- 3,2 /dev/ttyp2
- -crw- 3,3 /dev/ttyp3
- -crw- 3,4 /dev/ttyp4
- -crw- 3,5 /dev/ttyp5
- -crw- 3,6 /dev/ttyp6
- -crw- 3,7 /dev/ttyp7
- -crw- 3,8 /dev/ttyp8
- -crw- 3,9 /dev/ttyp9
- -crw- 3,10 /dev/ttypa
- -crw- 3,11 /dev/ttypb
- -crw- 3,12 /dev/ttypc
- -crw- 3,13 /dev/ttypd
- -crw- 3,14 /dev/ttype
- -crw- 3,15 /dev/ttypf
- -crw- 1,5 /dev/zero
- -crwx 10,111 /dev/dtedrv
- -crwx 4,110 /dev/ttyM
- -crw- 77,1 /dev/tssnd
- -crw- 77,2 /dev/tstone
- -crw- 2,1 /dev/ptyp1
- -crwx 10,180 /dev/triohook
- -crw- 90,0 /dev/mtd0
- -brw- 44,0 /dev/ftl0
- -crw- 10,175 /dev/tporta
- -crw- 10,176 /dev/tportb
- -crwx 10,100 /dev/softmodem
- -crwx 10,101 /dev/softmodem_signals
- -crwx 10,181 /dev/triovoice
- -crw- 5,67 /dev/cua3
- -crw- 5,68 /dev/cua4
- -crw- 5,69 /dev/cua5
- diff --exclude CVS -urN genext2fs-1.3.orig/device_table.txt genext2fs/device_table.txt
- --- genext2fs-1.3.orig/device_table.txt 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/device_table.txt 2004-10-24 02:43:50.000000000 -0600
- @@ -0,0 +1,129 @@
- +# When building a target filesystem, it is desirable to not have to
- +# become root and then run 'mknod' a thousand times. Using a device
- +# table you can create device nodes and directories "on the fly".
- +#
- +# This is a sample device table file for use with genext2fs. You can
- +# do all sorts of interesting things with a device table file. For
- +# example, if you want to adjust the permissions on a particular file
- +# you can just add an entry like:
- +# /sbin/foobar f 2755 0 0 - - - - -
- +# and (assuming the file /sbin/foobar exists) it will be made setuid
- +# root (regardless of what its permissions are on the host filesystem.
- +# Furthermore, you can use a single table entry to create a many device
- +# minors. For example, if I wanted to create /dev/hda and /dev/hda[0-15]
- +# I could just use the following two table entries:
- +# /dev/hda b 640 0 0 3 0 0 0 -
- +# /dev/hda b 640 0 0 3 1 1 1 15
- +#
- +# Device table entries take the form of:
- +# <name> <type> <mode> <uid> <gid> <major> <minor> <start> <inc> <count>
- +# where name is the file name, type can be one of:
- +# f A regular file
- +# d Directory
- +# c Character special device file
- +# b Block special device file
- +# p Fifo (named pipe)
- +# uid is the user id for the target file, gid is the group id for the
- +# target file. The rest of the entries (major, minor, etc) apply only
- +# to device special files.
- +
- +# Have fun
- +# -Erik Andersen <andersen@codepoet.org>
- +#
- +
- +#<name> <type> <mode> <uid> <gid> <major> <minor> <start> <inc> <count>
- +/dev d 755 0 0 - - - - -
- +/dev/mem c 640 0 0 1 1 0 0 -
- +/dev/kmem c 640 0 0 1 2 0 0 -
- +/dev/null c 640 0 0 1 3 0 0 -
- +/dev/zero c 640 0 0 1 5 0 0 -
- +/dev/random c 640 0 0 1 8 0 0 -
- +/dev/urandom c 640 0 0 1 9 0 0 -
- +/dev/tty c 666 0 0 5 0 0 0 -
- +/dev/tty c 666 0 0 4 0 0 1 6
- +/dev/console c 640 0 0 5 1 0 0 -
- +/dev/ram b 640 0 0 1 1 0 0 -
- +/dev/ram b 640 0 0 1 0 0 1 4
- +/dev/loop b 640 0 0 7 0 0 1 2
- +/dev/ptmx c 666 0 0 5 2 0 0 -
- +#/dev/ttyS c 640 0 0 4 64 0 1 4
- +#/dev/psaux c 640 0 0 10 1 0 0 -
- +#/dev/rtc c 640 0 0 10 135 0 0 -
- +
- +# Adjust permissions on some normal files
- +#/etc/shadow f 600 0 0 - - - - -
- +#/bin/tinylogin f 4755 0 0 - - - - -
- +
- +# User-mode Linux stuff
- +/dev/ubda b 640 0 0 98 0 0 0 -
- +/dev/ubda b 640 0 0 98 1 1 1 15
- +
- +# IDE Devices
- +/dev/hda b 640 0 0 3 0 0 0 -
- +/dev/hda b 640 0 0 3 1 1 1 15
- +/dev/hdb b 640 0 0 3 64 0 0 -
- +/dev/hdb b 640 0 0 3 65 1 1 15
- +#/dev/hdc b 640 0 0 22 0 0 0 -
- +#/dev/hdc b 640 0 0 22 1 1 1 15
- +#/dev/hdd b 640 0 0 22 64 0 0 -
- +#/dev/hdd b 640 0 0 22 65 1 1 15
- +#/dev/hde b 640 0 0 33 0 0 0 -
- +#/dev/hde b 640 0 0 33 1 1 1 15
- +#/dev/hdf b 640 0 0 33 64 0 0 -
- +#/dev/hdf b 640 0 0 33 65 1 1 15
- +#/dev/hdg b 640 0 0 34 0 0 0 -
- +#/dev/hdg b 640 0 0 34 1 1 1 15
- +#/dev/hdh b 640 0 0 34 64 0 0 -
- +#/dev/hdh b 640 0 0 34 65 1 1 15
- +
- +# SCSI Devices
- +#/dev/sda b 640 0 0 8 0 0 0 -
- +#/dev/sda b 640 0 0 8 1 1 1 15
- +#/dev/sdb b 640 0 0 8 16 0 0 -
- +#/dev/sdb b 640 0 0 8 17 1 1 15
- +#/dev/sdc b 640 0 0 8 32 0 0 -
- +#/dev/sdc b 640 0 0 8 33 1 1 15
- +#/dev/sdd b 640 0 0 8 48 0 0 -
- +#/dev/sdd b 640 0 0 8 49 1 1 15
- +#/dev/sde b 640 0 0 8 64 0 0 -
- +#/dev/sde b 640 0 0 8 65 1 1 15
- +#/dev/sdf b 640 0 0 8 80 0 0 -
- +#/dev/sdf b 640 0 0 8 81 1 1 15
- +#/dev/sdg b 640 0 0 8 96 0 0 -
- +#/dev/sdg b 640 0 0 8 97 1 1 15
- +#/dev/sdh b 640 0 0 8 112 0 0 -
- +#/dev/sdh b 640 0 0 8 113 1 1 15
- +#/dev/sg c 640 0 0 21 0 0 1 15
- +#/dev/scd b 640 0 0 11 0 0 1 15
- +#/dev/st c 640 0 0 9 0 0 1 8
- +#/dev/nst c 640 0 0 9 128 0 1 8
- +#/dev/st c 640 0 0 9 32 1 1 4
- +#/dev/st c 640 0 0 9 64 1 1 4
- +#/dev/st c 640 0 0 9 96 1 1 4
- +
- +# Floppy disk devices
- +#/dev/fd b 640 0 0 2 0 0 1 2
- +#/dev/fd0d360 b 640 0 0 2 4 0 0 -
- +#/dev/fd1d360 b 640 0 0 2 5 0 0 -
- +#/dev/fd0h1200 b 640 0 0 2 8 0 0 -
- +#/dev/fd1h1200 b 640 0 0 2 9 0 0 -
- +#/dev/fd0u1440 b 640 0 0 2 28 0 0 -
- +#/dev/fd1u1440 b 640 0 0 2 29 0 0 -
- +#/dev/fd0u2880 b 640 0 0 2 32 0 0 -
- +#/dev/fd1u2880 b 640 0 0 2 33 0 0 -
- +
- +# All the proprietary cdrom devices in the world
- +#/dev/aztcd b 640 0 0 29 0 0 0 -
- +#/dev/bpcd b 640 0 0 41 0 0 0 -
- +#/dev/capi20 c 640 0 0 68 0 0 1 2
- +#/dev/cdu31a b 640 0 0 15 0 0 0 -
- +#/dev/cdu535 b 640 0 0 24 0 0 0 -
- +#/dev/cm206cd b 640 0 0 32 0 0 0 -
- +#/dev/sjcd b 640 0 0 18 0 0 0 -
- +#/dev/sonycd b 640 0 0 15 0 0 0 -
- +#/dev/gscd b 640 0 0 16 0 0 0 -
- +#/dev/sbpcd b 640 0 0 25 0 0 0 -
- +#/dev/sbpcd b 640 0 0 25 0 0 1 4
- +#/dev/mcd b 640 0 0 23 0 0 0 -
- +#/dev/optcd b 640 0 0 17 0 0 0 -
- +
- diff --exclude CVS -urN genext2fs-1.3.orig/genext2fs.8 genext2fs/genext2fs.8
- --- genext2fs-1.3.orig/genext2fs.8 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/genext2fs.8 2004-10-24 02:43:50.000000000 -0600
- @@ -0,0 +1,129 @@
- +.\" Hey, EMACS: -*- nroff -*-
- +.\" First parameter, NAME, should be all caps
- +.\" Second parameter, SECTION, should be 1-8, maybe w/ subsection
- +.\" other parameters are allowed: see man(7), man(1)
- +.TH GENEXT2FS 8 "July 14, 2001"
- +.\" Please adjust this date whenever revising the manpage.
- +.\"
- +.\" Some roff macros, for reference:
- +.\" .nh disable hyphenation
- +.\" .hy enable hyphenation
- +.\" .ad l left justify
- +.\" .ad b justify to both left and right margins
- +.\" .nf disable filling
- +.\" .fi enable filling
- +.\" .br insert line break
- +.\" .sp <n> insert n+1 empty lines
- +.\" for manpage-specific macros, see man(7)
- +.SH NAME
- +genext2fs \- ext2 filesystem generator for embedded systems
- +.SH SYNOPSIS
- +.B genext2fs
- +.RI [ options ] " image"
- +.SH DESCRIPTION
- +\fBgenext2fs\fP generates an ext2 filesystem
- +as a normal (non-root) user. It doesn't require you to mount
- +the image file to copy files on it. It doesn't even require
- +you to be the superuser to make device nodes.
- +.SH WARNING
- +\fBgenext2fs\fP has been designed for embedded
- +systems. As such, it will generate a filesystem for single-user
- +usage: all files/directories/etc... will belong to UID/GID 0
- +.SH OPTIONS
- +.TP
- +.BI -x \ image
- +Use this image as a starting point
- +.TP
- +.BI -d \ directory
- +Add this directory as source
- +.TP
- +.BI -f \ FILE
- +.TP
- +.BI -D \ FILE
- +Uses the named FILE as a device table file, to create device
- +nodes and directories "on the fly".
- +.TP
- +.BI -b \ blocks
- +Size in blocks
- +.TP
- +.BI -i \ inodes
- +Number of inodes
- +.TP
- +.BI -r \ reserved
- +Number of reserved blocks
- +.TP
- +.BI -g \ path
- +Generate a block map file for this path
- +.TP
- +.BI -e \ value
- +Fill unallocated blocks with value
- +.TP
- +.BI -z
- +Make files with holes
- +.TP
- +.BI -U
- +Squash owners making all files be owned by root
- +.TP
- +.BI -P
- +Squash permissions on all files
- +.TP
- +.BI -q
- +Squash permissions and owners (same as -P -U)
- +.TP
- +.BI -v
- +Print resulting filesystem structure
- +.TP
- +.BI -h
- +Display help
- +.TP
- +.SH EXAMPLES
- +
- +.EX
- +.B
- + genext2fs -b 1440 -d src /dev/fd0
- +.EE
- +
- +All files in the
- +.I src
- +directory will be written to
- +.B /dev/fd0
- +as a new ext2 filesystem image. You can then mount the floppy as
- +usual.
- +
- +.EX
- +.B
- + genext2fs -b 1024 -d src -D device_table.txt flashdisk.img
- +.EE
- +
- +This example builds a filesystem from all the files in
- +.I src
- +, then device nodes are created based on the content the device_table file
- +.I dev.txt.
- +An example device file follows:
- +
- +.EX
- + #<name> <type> <mode> <uid> <gid> <major> <minor> <start> <inc> <count>
- + /dev d 755 0 0 - - - - -
- + /dev/mem c 640 0 0 1 1 0 0 -
- + /dev/tty c 666 0 0 5 0 0 0 -
- + /dev/tty c 666 0 0 4 0 0 1 6
- + /dev/loop b 640 0 0 7 0 0 1 2
- + /dev/hda b 640 0 0 3 0 0 0 -
- + /dev/hda b 640 0 0 3 1 1 1 16
- +.EE
- +
- +This device table creates the /dev directory, a character device
- +node /dev/mem (major 1, minor 1), it also creates /dev/tty,
- +/dev/tty[0-5], /dev/loop[0-1], /dev/hda, and /dev/hda0 to /dev/hda15
- +.SH BUGS
- +\fBgenext2fs\fP does not support hard links. Hard links present in the input
- +tree will be represented as separate files in the ext2 image.
- +
- +.SH SEE ALSO
- +.BR mkfs (8),
- +.BR genromfs (8),
- +.BR mkisofs (8).
- +.br
- +.SH AUTHOR
- +This manual page was written by David Kimdon <dwhedon@debian.org>,
- +for the Debian GNU/Linux system (but may be used by others).
- diff --exclude CVS -urN genext2fs-1.3.orig/genext2fs.c genext2fs/genext2fs.c
- --- genext2fs-1.3.orig/genext2fs.c 2001-06-18 02:11:32.000000000 -0600
- +++ genext2fs/genext2fs.c 2004-12-08 04:51:42.000000000 -0700
- @@ -1,8 +1,14 @@
- +/* vi: set sw=8 ts=8: */
- // genext2fs.c
- //
- // ext2 filesystem generator for embedded systems
- // Copyright (C) 2000 Xavier Bestel <xavier.bestel@free.fr>
- //
- +// 'du' portions taken from coreutils/du.c in busybox:
- +// Copyright (C) 1999,2000 by Lineo, inc. and John Beppu
- +// Copyright (C) 1999,2000,2001 by John Beppu <beppu@codepoet.org>
- +// Copyright (C) 2002 Edward Betts <edward@debian.org>
- +//
- // 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; version
- @@ -26,6 +32,23 @@
- // Bugfix: getcwd values for Solaris xavier.gueguen@col.bsf.alcatel.fr
- // Bugfix: ANSI scanf for non-GNU C xavier.gueguen@col.bsf.alcatel.fr
- // 28 Jun 2001 Bugfix: getcwd differs for Solaris/GNU mike@sowbug.com
- +// 8 Mar 2002 Bugfix: endianness swap of x-indirects
- +// 23 Mar 2002 Bugfix: test for IFCHR or IFBLK was flawed
- +// 10 Oct 2002 Added comments,makefile targets, vsundar@ixiacom.com
- +// endianess swap assert check.
- +// Copyright (C) 2002 Ixia communications
- +// 12 Oct 2002 Added support for triple indirection vsundar@ixiacom.com
- +// Copyright (C) 2002 Ixia communications
- +// 14 Oct 2002 Added support for groups vsundar@ixiacom.com
- +// Copyright (C) 2002 Ixia communications
- +// 5 Jan 2003 Bugfixes: reserved inodes should be set vsundar@usc.edu
- +// only in the first group; directory names
- +// need to be null padded at the end; and
- +// number of blocks per group should be a
- +// multiple of 8. Updated md5 values.
- +// 6 Jan 2003 Erik Andersen <andersee@debian.org> added
- +// mkfs.jffs2 compatible device table support,
- +// along with -q, -P, -U
-
-
- // `genext2fs' is a mean to generate an ext2 filesystem
- @@ -33,10 +56,6 @@
- // the image file to copy files on it. It doesn't even require
- // you to be the superuser to make device nodes.
- //
- -// Warning ! `genext2fs' has been designed for embedded
- -// systems. As such, it will generate a filesystem for single-user
- -// usage: all files/directories/etc... will belong to UID/GID 0
- -//
- // Example usage:
- //
- // # genext2fs -b 1440 -d srcdir /dev/fd0
- @@ -45,41 +64,131 @@
- // a new ext2 filesystem image. You can then mount the floppy as
- // usual.
- //
- -// # genext2fs -b 1024 -d builddir -f devices.txt flashdisk.img
- +// # genext2fs -b 1024 -d builddir -D device_table.txt flashdisk.img
- //
- // This one would build a filesystem from all the files in builddir,
- -// then would read a devices list and make apropriate nodes. The
- -// format for the device list is:
- -//
- -// drwx /dev
- -// crw- 10,190 /dev/lcd
- -// brw- 1,0 /dev/ram0
- -//
- -// This device list builds the /dev directory, a character device
- -// node /dev/lcd (major 10, minor 190) and a block device node
- -// /dev/ram0 (major 1, minor 0)
- -
- +// then would read the device_table.txt file and make apropriate nodes.
- +// The format for the device table file is covered in detail in the sample
- +// device_table.txt file provided with the genext2fs source.
-
- +#define _GNU_SOURCE
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- #include <dirent.h>
- +#include <libgen.h>
- #include <stdarg.h>
- #include <unistd.h>
- #include <sys/stat.h>
- +#include <assert.h>
- +#include <time.h>
- +#include <ctype.h>
- +#include <errno.h>
- +#include <fcntl.h>
- +#include <sys/types.h>
- +#include <getopt.h>
- +
- +struct stats {
- + unsigned long nblocks;
- + unsigned long ninodes;
- +};
- +
- +#if 0
- +#define HASH_SIZE 311 /* Should be prime */
- +#define hash_inode(i) ((i) % HASH_SIZE)
- +
- +typedef struct ino_dev_hash_bucket_struct {
- + struct ino_dev_hash_bucket_struct *next;
- + ino_t ino;
- + dev_t dev;
- + char name[1];
- +} ino_dev_hashtable_bucket_t;
- +
- +static ino_dev_hashtable_bucket_t *ino_dev_hashtable[HASH_SIZE];
- +
- +static int is_in_ino_dev_hashtable(const struct stat *statbuf, char **name)
- +{
- + ino_dev_hashtable_bucket_t *bucket;
- +
- + bucket = ino_dev_hashtable[hash_inode(statbuf->st_ino)];
- + while (bucket != NULL) {
- + if ((bucket->ino == statbuf->st_ino) &&
- + (bucket->dev == statbuf->st_dev))
- + {
- + if (name) *name = bucket->name;
- + return 1;
- + }
- + bucket = bucket->next;
- + }
- + return 0;
- +}
-
- +/* Add statbuf to statbuf hash table */
- +static void add_to_ino_dev_hashtable(const struct stat *statbuf, const char *name)
- +{
- + int i;
- + size_t s;
- + ino_dev_hashtable_bucket_t *bucket;
- +
- + i = hash_inode(statbuf->st_ino);
- + s = name ? strlen(name) : 0;
- + bucket = malloc(sizeof(ino_dev_hashtable_bucket_t) + s);
- + bucket->ino = statbuf->st_ino;
- + bucket->dev = statbuf->st_dev;
- + if (name)
- + strcpy(bucket->name, name);
- + else
- + bucket->name[0] = '\0';
- + bucket->next = ino_dev_hashtable[i];
- + ino_dev_hashtable[i] = bucket;
- +}
-
- +/* Clear statbuf hash table */
- +static void reset_ino_dev_hashtable(void)
- +{
- + int i;
- + ino_dev_hashtable_bucket_t *bucket;
-
- + for (i = 0; i < HASH_SIZE; i++) {
- + while (ino_dev_hashtable[i] != NULL) {
- + bucket = ino_dev_hashtable[i]->next;
- + free(ino_dev_hashtable[i]);
- + ino_dev_hashtable[i] = bucket;
- + }
- + }
- +}
- +
- +static int count_ino_in_hashtable(void)
- +{
- + long count = 0;
- + int i;
- +
- + for (i = 0; i < HASH_SIZE; i++) {
- + ino_dev_hashtable_bucket_t *bucket = ino_dev_hashtable[i];
- + while (bucket != NULL) {
- + count++;
- + bucket = bucket->next;
- + }
- + }
- +
- + return count;
- +}
- +#endif
-
- // block size
-
- #define BLOCKSIZE 1024
- #define BLOCKS_PER_GROUP 8192
- #define BYTES_PER_INODE (8*BLOCKSIZE)
- -#define RESERVED_INODES 5/100
- +/* Percentage of blocks that are reserved.*/
- +#define RESERVED_BLOCKS 5/100
- +#define MAX_RESERVED_BLOCKS 25/100
-
-
- // inode block size (why is it != BLOCKSIZE ?!?)
- +/* The field i_blocks in the ext2 inode stores the number of data blocks
- + but in terms of 512 bytes. That is what INODE_BLOCKSIZE represents.
- + INOBLK is the number of such blocks in an actual disk block */
-
- #define INODE_BLOCKSIZE 512
- #define INOBLK (BLOCKSIZE / INODE_BLOCKSIZE)
- @@ -115,18 +224,20 @@
- // file modes
-
- #define FM_IFMT 0xF000 // format mask
- -#define FM_IFLNK 0xA000 // socket
- -#define FM_IFSOCK 0xC000 // symbolic link
- +#define FM_IFLNK 0xA000 // symbolic link
- +#define FM_IFSOCK 0xC000 // socket
- #define FM_IFREG 0x8000 // regular file
- #define FM_IFBLK 0x6000 // block device
- #define FM_IFDIR 0x4000 // directory
- #define FM_IFCHR 0x2000 // character device
- #define FM_IFIFO 0x1000 // fifo
-
- +#define FM_IMASK 0x0FFF // all perms
- #define FM_ISUID 0x0800 // SUID
- #define FM_ISGID 0x0400 // SGID
- #define FM_ISVTX 0x0200 // sticky bit
-
- +
- #define FM_IRWXU 0x01C0 // user mask
- #define FM_IRUSR 0x0100 // read
- #define FM_IWUSR 0x0080 // write
- @@ -147,6 +258,39 @@
-
- #define OP_HOLES 0x01 // make files with holes
-
- +/* Defines for accessing group details */
- +
- +// Number of groups in the filesystem
- +#define GRP_NBGROUPS(fs) (((fs)->sb.s_blocks_count+(fs)->sb.s_blocks_per_group-1)/(fs)->sb.s_blocks_per_group)
- +
- +// Get group block bitmap (bbm) given the group number
- +#define GRP_GET_GROUP_BBM(fs,grp) ( get_blk((fs),(fs)->gd[(grp)].bg_block_bitmap) )
- +
- +// Get group inode bitmap (ibm) given the group number
- +#define GRP_GET_GROUP_IBM(fs,grp) ( get_blk((fs),(fs)->gd[(grp)].bg_inode_bitmap) )
- +
- +// Given an inode number find the group it belongs to
- +#define GRP_GROUP_OF_INODE(fs,nod) ( ((nod)-1) / (fs)->sb.s_inodes_per_group)
- +
- +//Given an inode number get the inode bitmap that covers it
- +#define GRP_GET_INODE_BITMAP(fs,nod) \
- + ( GRP_GET_GROUP_IBM((fs),GRP_GROUP_OF_INODE((fs),(nod))) )
- +
- +//Given an inode number find its offset within the inode bitmap that covers it
- +#define GRP_IBM_OFFSET(fs,nod) \
- + ( (nod) - GRP_GROUP_OF_INODE((fs),(nod))*(fs)->sb.s_inodes_per_group )
- +
- +// Given a block number find the group it belongs to
- +#define GRP_GROUP_OF_BLOCK(fs,blk) ( ((blk)-1) / (fs)->sb.s_blocks_per_group)
- +
- +//Given a block number get the block bitmap that covers it
- +#define GRP_GET_BLOCK_BITMAP(fs,blk) \
- + ( GRP_GET_GROUP_BBM((fs),GRP_GROUP_OF_BLOCK((fs),(blk))) )
- +
- +//Given a block number find its offset within the block bitmap that covers it
- +#define GRP_BBM_OFFSET(fs,blk) \
- + ( (blk) - GRP_GROUP_OF_BLOCK((fs),(blk))*(fs)->sb.s_blocks_per_group )
- +
-
- // used types
-
- @@ -176,7 +320,7 @@
- #define SCANF_PREFIX "511"
- #define SCANF_STRING(s) (s = malloc(512))
- #define GETCWD_SIZE -1
- -inline int snprintf(char *str, size_t n, const char *fmt, ...)
- +static inline int snprintf(char *str, size_t n, const char *fmt, ...)
- {
- int ret;
- va_list ap;
- @@ -190,12 +334,12 @@
-
- // endianness swap
-
- -inline uint16 swab16(uint16 val)
- +static inline uint16 swab16(uint16 val)
- {
- return (val >> 8) | (val << 8);
- }
-
- -inline uint32 swab32(uint32 val)
- +static inline uint32 swab32(uint32 val)
- {
- return ((val>>24) | ((val>>8)&0xFF00) |
- ((val<<8)&0xFF0000) | (val<<24));
- @@ -287,7 +431,6 @@
- {
- groupdescriptor_decl
- uint32 bg_reserved[3];
- - uint32 bg_pad_to_bk[(BLOCKSIZE-32)/sizeof(uint32)];
- } groupdescriptor;
-
- typedef struct
- @@ -304,6 +447,32 @@
-
- typedef uint8 block[BLOCKSIZE];
-
- +/* blockwalker fields:
- + The blockwalker is used to access all the blocks of a file (including
- + the indirection blocks) through repeated calls to walk_bw.
- +
- + bpdir -> index into the inode->i_block[]. Indicates level of indirection.
- + bnum -> total number of blocks so far accessed. including indirection
- + blocks.
- + bpind,bpdind,bptind -> index into indirection blocks.
- +
- + bpind, bpdind, bptind do *NOT* index into single, double and triple
- + indirect blocks resp. as you might expect from their names. Instead
- + they are in order the 1st, 2nd & 3rd index to be used
- +
- + As an example..
- + To access data block number 70000:
- + bpdir: 15 (we are doing triple indirection)
- + bpind: 0 ( index into the triple indirection block)
- + bpdind: 16 ( index into the double indirection block)
- + bptind: 99 ( index into the single indirection block)
- + 70000 = 12 + 256 + 256*256 + 16*256 + 100 (indexing starts from zero)
- +
- + So,for double indirection bpind will index into the double indirection
- + block and bpdind into the single indirection block. For single indirection
- + only bpind will be used.
- +*/
- +
- typedef struct
- {
- uint32 bnum;
- @@ -313,15 +482,14 @@
- uint32 bptind;
- } blockwalker;
-
- +
- +/* Filesystem structure that support groups */
- #if BLOCKSIZE == 1024
- typedef struct
- {
- - block zero; // The famous block 0
- - superblock sb; // The superblock
- - groupdescriptor gd; // The group desciptor
- - block bbm; // The block bitmap
- - block ibm; // The inode bitmap
- - inode itab[0]; // The inode table
- + block zero; // The famous block 0
- + superblock sb; // The superblock
- + groupdescriptor gd[0]; // The group descriptors
- } filesystem;
- #else
- #error UNHANDLED BLOCKSIZE
- @@ -345,35 +513,35 @@
- #define udecl32(x) this->x = swab32(this->x);
- #define utdecl32(x,n) { int i; for(i=0; i<n; i++) this->x[i] = swab32(this->x[i]); }
-
- -void swap_sb(superblock *sb)
- +static void swap_sb(superblock *sb)
- {
- #define this sb
- superblock_decl
- #undef this
- }
-
- -void swap_gd(groupdescriptor *gd)
- +static void swap_gd(groupdescriptor *gd)
- {
- #define this gd
- groupdescriptor_decl
- #undef this
- }
-
- -void swap_nod(inode *nod)
- +static void swap_nod(inode *nod)
- {
- #define this nod
- inode_decl
- #undef this
- }
-
- -void swap_dir(directory *dir)
- +static void swap_dir(directory *dir)
- {
- #define this dir
- directory_decl
- #undef this
- }
-
- -void swap_block(block b)
- +static void swap_block(block b)
- {
- int i;
- uint32 *blk = (uint32*)b;
- @@ -389,67 +557,158 @@
- #undef udecl32
- #undef utdecl32
-
- -char * argv0;
- +static char * app_name;
- +static const char *const memory_exhausted = "memory exhausted";
-
- // error (un)handling
- -inline void errexit(const char *fmt, ...)
- +static void verror_msg(const char *s, va_list p)
- {
- - va_list ap;
- - fprintf(stderr, "%s: ", argv0);
- - va_start(ap, fmt);
- - vfprintf(stderr, fmt, ap);
- - va_end(ap);
- - fprintf(stderr, "\n");
- - exit(1);
- + fflush(stdout);
- + fprintf(stderr, "%s: ", app_name);
- + vfprintf(stderr, s, p);
- +}
- +static void error_msg(const char *s, ...)
- +{
- + va_list p;
- + va_start(p, s);
- + verror_msg(s, p);
- + va_end(p);
- + putc('\n', stderr);
- +}
- +
- +static void error_msg_and_die(const char *s, ...)
- +{
- + va_list p;
- + va_start(p, s);
- + verror_msg(s, p);
- + va_end(p);
- + putc('\n', stderr);
- + exit(EXIT_FAILURE);
- +}
- +
- +static void vperror_msg(const char *s, va_list p)
- +{
- + int err = errno;
- + if (s == 0)
- + s = "";
- + verror_msg(s, p);
- + if (*s)
- + s = ": ";
- + fprintf(stderr, "%s%s\n", s, strerror(err));
- +}
- +#if 0
- +static void perror_msg(const char *s, ...)
- +{
- + va_list p;
- + va_start(p, s);
- + vperror_msg(s, p);
- + va_end(p);
- +}
- +#endif
- +static void perror_msg_and_die(const char *s, ...)
- +{
- + va_list p;
- + va_start(p, s);
- + vperror_msg(s, p);
- + va_end(p);
- + exit(EXIT_FAILURE);
- +}
- +
- +static FILE *xfopen(const char *path, const char *mode)
- +{
- + FILE *fp;
- + if ((fp = fopen(path, mode)) == NULL)
- + perror_msg_and_die("%s", path);
- + return fp;
- +}
- +
- +static char *xstrdup(const char *s)
- +{
- + char *t;
- +
- + if (s == NULL)
- + return NULL;
- + t = strdup(s);
- + if (t == NULL)
- + error_msg_and_die(memory_exhausted);
- + return t;
- }
-
- -inline void pexit(const char * fname)
- +static void *xrealloc(void *ptr, size_t size)
- {
- - fprintf(stderr, "%s: ", argv0);
- - perror(fname);
- - exit(1);
- + ptr = realloc(ptr, size);
- + if (ptr == NULL && size != 0)
- + error_msg_and_die(memory_exhausted);
- + return ptr;
- +}
- +
- +static char *xreadlink(const char *path)
- +{
- + static const int GROWBY = 80; /* how large we will grow strings by */
- +
- + char *buf = NULL;
- + int bufsize = 0, readsize = 0;
- +
- + do {
- + buf = xrealloc(buf, bufsize += GROWBY);
- + readsize = readlink(path, buf, bufsize); /* 1st try */
- + if (readsize == -1) {
- + perror_msg_and_die("%s:%s", app_name, path);
- + }
- + }
- + while (bufsize < readsize + 1);
- +
- + buf[readsize] = '\0';
- + return buf;
- }
-
- // printf helper macro
- #define plural(a) (a), ((a) > 1) ? "s" : ""
-
- // temporary working block
- -inline uint8 * get_workblk(void)
- +static inline uint8 * get_workblk(void)
- {
- - static block b;
- + unsigned char* b=calloc(1,BLOCKSIZE);
- return b;
- }
- -inline void free_workblk(block b)
- +static inline void free_workblk(block b)
- {
- + free(b);
- }
-
- -// rounds a quantity up to a blocksize
- -uint32 rndup(uint32 qty, uint32 siz)
- +/* Rounds qty upto a multiple of siz. siz should be a power of 2 */
- +static uint32 rndup(uint32 qty, uint32 siz)
- {
- return (qty + (siz - 1)) & ~(siz - 1);
- }
-
- // check if something is allocated in the bitmap
- -inline uint32 allocated(block b, uint32 item)
- +static inline uint32 allocated(block b, uint32 item)
- {
- return b[(item-1) / 8] & (1 << ((item-1) % 8));
- }
-
- // return a given block from a filesystem
- -inline uint8 * get_blk(filesystem *fs, uint32 blk)
- +static inline uint8 * get_blk(filesystem *fs, uint32 blk)
- {
- return (uint8*)fs + blk*BLOCKSIZE;
- }
-
- // return a given inode from a filesystem
- -inline inode * get_nod(filesystem *fs, uint32 nod)
- +static inline inode * get_nod(filesystem *fs, uint32 nod)
- {
- - return &fs->itab[nod-1];
- + int grp,offset;
- + inode *itab;
- +
- + offset = GRP_IBM_OFFSET(fs,nod);
- + grp = GRP_GROUP_OF_INODE(fs,nod);
- + itab = (inode *)get_blk(fs, fs->gd[grp].bg_inode_table);
- + return itab+offset-1;
- }
-
- // allocate a given block/inode in the bitmap
- // allocate first free if item == 0
- -uint32 allocate(block b, uint32 item)
- +static uint32 allocate(block b, uint32 item)
- {
- if(!item)
- {
- @@ -473,39 +732,67 @@
- }
-
- // deallocate a given block/inode
- -void deallocate(block b, uint32 item)
- +static void deallocate(block b, uint32 item)
- {
- b[(item-1) / 8] &= ~(1 << ((item-1) % 8));
- }
-
- // allocate a block
- -uint32 alloc_blk(filesystem *fs)
- +static uint32 alloc_blk(filesystem *fs, uint32 nod)
- {
- - uint32 bk;
- - if(!(bk = allocate(fs->bbm, 0)))
- - errexit("couldn't allocate a block (no free space)");
- - if(!(fs->gd.bg_free_blocks_count--))
- - errexit("group descr. free blocks count == 0 (corrupted fs?)");
- + uint32 bk=0;
- + uint32 grp,nbgroups;
- +
- + grp = nod/fs->sb.s_inodes_per_group;
- + nbgroups = ( fs->sb.s_blocks_count - fs->sb.s_first_data_block + fs->sb.s_blocks_per_group -1 ) /
- + fs->sb.s_blocks_per_group;
- + if(!(bk = allocate(get_blk(fs,fs->gd[grp].bg_block_bitmap), 0))) {
- + for(grp=0;grp<nbgroups && !bk;grp++)
- + bk=allocate(get_blk(fs,fs->gd[grp].bg_block_bitmap),0);
- + grp--;
- + }
- + if (!bk)
- + error_msg_and_die("couldn't allocate a block (no free space)");
- + if(!(fs->gd[grp].bg_free_blocks_count--))
- + error_msg_and_die("group descr %d. free blocks count == 0 (corrupted fs?)",grp);
- if(!(fs->sb.s_free_blocks_count--))
- - errexit("superblock free blocks count == 0 (corrupted fs?)");
- - return bk;
- + error_msg_and_die("superblock free blocks count == 0 (corrupted fs?)");
- + return fs->sb.s_blocks_per_group*grp + bk;
- }
-
- // allocate an inode
- -uint32 alloc_nod(filesystem *fs)
- +static uint32 alloc_nod(filesystem *fs)
- {
- - uint32 nod;
- - if(!(nod = allocate(fs->ibm, 0)))
- - errexit("couldn't allocate an inode (no free inode)");
- - if(!(fs->gd.bg_free_inodes_count--))
- - errexit("group descr. free blocks count == 0 (corrupted fs?)");
- + uint32 nod=0,best_group=0;
- + uint32 grp,nbgroups,avefreei;
- +
- + nbgroups = ( fs->sb.s_blocks_count - fs->sb.s_first_data_block + fs->sb.s_blocks_per_group -1 ) /
- + fs->sb.s_blocks_per_group;
- +
- + /* Distribute inodes amongst all the blocks */
- + /* For every block group with more than average number of free inodes */
- + /* find the one with the most free blocks and allocate node there */
- + /* Idea from find_group_dir in fs/ext2/ialloc.c in 2.4.19 kernel */
- + /* We do it for all inodes. */
- + avefreei = fs->sb.s_free_inodes_count / nbgroups;
- + for(grp=0;grp<nbgroups && !nod;grp++) {
- + if (fs->gd[grp].bg_free_inodes_count < avefreei)
- + continue;
- + if (!best_group ||
- + fs->gd[grp].bg_free_blocks_count > fs->gd[best_group].bg_free_blocks_count)
- + best_group = grp;
- + }
- + if (!(nod = allocate(get_blk(fs,fs->gd[best_group].bg_inode_bitmap),0)))
- + error_msg_and_die("couldn't allocate an inode (no free inode)");
- + if(!(fs->gd[best_group].bg_free_inodes_count--))
- + error_msg_and_die("group descr. free blocks count == 0 (corrupted fs?)");
- if(!(fs->sb.s_free_inodes_count--))
- - errexit("superblock free blocks count == 0 (corrupted fs?)");
- - return nod;
- + error_msg_and_die("superblock free blocks count == 0 (corrupted fs?)");
- + return fs->sb.s_inodes_per_group*best_group+nod;
- }
-
- // print a bitmap allocation
- -void print_bm(block b, uint32 max)
- +static void print_bm(block b, uint32 max)
- {
- uint32 i;
- printf("----+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0\n");
- @@ -520,7 +807,7 @@
- }
-
- // initalize a blockwalker (iterator for blocks list)
- -void init_bw(filesystem *fs, uint32 nod, blockwalker *bw)
- +static void init_bw(filesystem *fs, uint32 nod, blockwalker *bw)
- {
- bw->bnum = 0;
- bw->bpdir = EXT2_INIT_BLOCK;
- @@ -529,7 +816,7 @@
- // return next block of inode (WALK_END for end)
- // if create>0, append a newly allocated block at the end
- // if hole!=0, create a hole in the file
- -uint32 walk_bw(filesystem *fs, uint32 nod, blockwalker *bw, uint32 *create, uint32 hole)
- +static uint32 walk_bw(filesystem *fs, uint32 nod, blockwalker *bw, uint32 *create, uint32 hole)
- {
- uint32 *bkref = 0;
- uint32 *b;
- @@ -546,14 +833,14 @@
- {
- bkref = &get_nod(fs, nod)->i_block[bw->bpdir = 0];
- if(extend) // allocate first block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // direct block
- else if(bw->bpdir < EXT2_NDIR_BLOCKS)
- {
- bkref = &get_nod(fs, nod)->i_block[++bw->bpdir];
- if(extend) // allocate block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // first block in indirect block
- else if(bw->bpdir == EXT2_NDIR_BLOCKS)
- @@ -562,11 +849,11 @@
- bw->bpdir = EXT2_IND_BLOCK;
- bw->bpind = 0;
- if(extend) // allocate indirect block
- - get_nod(fs, nod)->i_block[bw->bpdir] = alloc_blk(fs);
- + get_nod(fs, nod)->i_block[bw->bpdir] = alloc_blk(fs,nod);
- b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- bkref = &b[bw->bpind];
- if(extend) // allocate first block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // block in indirect block
- else if((bw->bpdir == EXT2_IND_BLOCK) && (bw->bpind < BLOCKSIZE/4 - 1))
- @@ -575,7 +862,7 @@
- b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- bkref = &b[bw->bpind];
- if(extend) // allocate block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // first block in first indirect block in first double indirect block
- else if(bw->bpdir == EXT2_IND_BLOCK)
- @@ -585,14 +872,14 @@
- bw->bpind = 0;
- bw->bpdind = 0;
- if(extend) // allocate double indirect block
- - get_nod(fs, nod)->i_block[bw->bpdir] = alloc_blk(fs);
- + get_nod(fs, nod)->i_block[bw->bpdir] = alloc_blk(fs,nod);
- b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- if(extend) // allocate first indirect block
- - b[bw->bpind] = alloc_blk(fs);
- + b[bw->bpind] = alloc_blk(fs,nod);
- b = (uint32*)get_blk(fs, b[bw->bpind]);
- bkref = &b[bw->bpdind];
- if(extend) // allocate first block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // block in indirect block in double indirect block
- else if((bw->bpdir == EXT2_DIND_BLOCK) && (bw->bpdind < BLOCKSIZE/4 - 1))
- @@ -602,7 +889,7 @@
- b = (uint32*)get_blk(fs, b[bw->bpind]);
- bkref = &b[bw->bpdind];
- if(extend) // allocate block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- // first block in indirect block in double indirect block
- else if((bw->bpdir == EXT2_DIND_BLOCK) && (bw->bpind < BLOCKSIZE/4 - 1))
- @@ -612,20 +899,100 @@
- bw->bpind++;
- b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- if(extend) // allocate indirect block
- - b[bw->bpind] = alloc_blk(fs);
- + b[bw->bpind] = alloc_blk(fs,nod);
- b = (uint32*)get_blk(fs, b[bw->bpind]);
- bkref = &b[bw->bpdind];
- if(extend) // allocate first block
- - *bkref = hole ? 0 : alloc_blk(fs);
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- + }
- +
- + /* Adding support for triple indirection */
- + /* Just starting triple indirection. Allocate the indirection
- + blocks and the first data block
- + */
- + else if (bw->bpdir == EXT2_DIND_BLOCK)
- + {
- + bw->bnum += 3;
- + bw->bpdir = EXT2_TIND_BLOCK;
- + bw->bpind = 0;
- + bw->bpdind = 0;
- + bw->bptind = 0;
- + if(extend) // allocate triple indirect block
- + get_nod(fs, nod)->i_block[bw->bpdir] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- + if(extend) // allocate first double indirect block
- + b[bw->bpind] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, b[bw->bpind]);
- + if(extend) // allocate first indirect block
- + b[bw->bpdind] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, b[bw->bpdind]);
- + bkref = &b[bw->bptind];
- + if(extend) // allocate first data block
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- + }
- + /* Still processing a single indirect block down the indirection
- + chain.Allocate a data block for it
- + */
- + else if ( (bw->bpdir == EXT2_TIND_BLOCK) &&
- + (bw->bptind < BLOCKSIZE/4 -1) )
- + {
- + bw->bptind++;
- + b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- + b = (uint32*)get_blk(fs, b[bw->bpind]);
- + b = (uint32*)get_blk(fs, b[bw->bpdind]);
- + bkref = &b[bw->bptind];
- + if(extend) // allocate data block
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- + }
- + /* Finished processing a single indirect block. But still in the
- + same double indirect block. Allocate new single indirect block
- + for it and a data block
- + */
- + else if ( (bw->bpdir == EXT2_TIND_BLOCK) &&
- + (bw->bpdind < BLOCKSIZE/4 -1) )
- + {
- + bw->bnum++;
- + bw->bptind = 0;
- + bw->bpdind++;
- + b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- + b = (uint32*)get_blk(fs, b[bw->bpind]);
- + if (extend) // allocate single indirect block
- + b[bw->bpdind] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, b[bw->bpdind]);
- + bkref = &b[bw->bptind];
- + if(extend) // allocate first data block
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- + }
- + /* Finished processing a double indirect block. Allocate the next
- + double indirect block and the single,data blocks for it
- + */
- + else if ( (bw->bpdir == EXT2_TIND_BLOCK) &&
- + (bw->bpind < BLOCKSIZE/4 - 1) )
- + {
- + bw->bnum += 2;
- + bw->bpdind = 0;
- + bw->bptind = 0;
- + bw->bpind++;
- + b = (uint32*)get_blk(fs, get_nod(fs, nod)->i_block[bw->bpdir]);
- + if(extend) // allocate double indirect block
- + b[bw->bpind] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, b[bw->bpind]);
- + if(extend) // allocate single indirect block
- + b[bw->bpdind] = alloc_blk(fs,nod);
- + b = (uint32*)get_blk(fs, b[bw->bpdind]);
- + bkref = &b[bw->bptind];
- + if(extend) // allocate first block
- + *bkref = hole ? 0 : alloc_blk(fs,nod);
- }
- - // I don't do triple indirect - it's such a small filesystem ...
- else
- - errexit("file too big ! blocks list for inode %d extends past double indirect blocks!", nod);
- + error_msg_and_die("file too big !");
- + /* End change for walking triple indirection */
- +
- if(*bkref)
- {
- bw->bnum++;
- - if(!allocated(fs->bbm, *bkref))
- - errexit("[block %d of inode %d is unallocated !]", *bkref, nod);
- + if(!allocated(GRP_GET_BLOCK_BITMAP(fs,*bkref), GRP_BBM_OFFSET(fs,*bkref)))
- + error_msg_and_die("[block %d of inode %d is unallocated !]", *bkref, nod);
- }
- if(extend)
- get_nod(fs, nod)->i_blocks = bw->bnum * INOBLK;
- @@ -633,7 +1000,7 @@
- }
-
- // add blocks to an inode (file/dir/etc...)
- -void extend_blk(filesystem *fs, uint32 nod, block b, int amount)
- +static void extend_blk(filesystem *fs, uint32 nod, block b, int amount)
- {
- int create = amount;
- blockwalker bw, lbw;
- @@ -662,24 +1029,35 @@
- }
- }
-
- +static void truncate_nod(filesystem *fs, uint32 nod)
- +{
- + inode *node = get_nod(fs, nod);
- +assert(!node->i_size);
- +#warning truncate_nod() no yet implemented
- +}
- +
- // link an entry (inode #) to a directory
- -void add2dir(filesystem *fs, uint32 dnod, uint32 nod, const char* name)
- +static void add2dir(filesystem *fs, uint32 dnod, uint32 nod, const char* name)
- {
- blockwalker bw;
- uint32 bk;
- uint8 *b;
- directory *d;
- int reclen, nlen;
- - if((get_nod(fs, dnod)->i_mode & FM_IFMT) != FM_IFDIR)
- - errexit("can't add '%s' to a non-directory", name);
- + inode *node;
- + inode *pnode;
- +
- + pnode = get_nod(fs, dnod);
- + if((pnode->i_mode & FM_IFMT) != FM_IFDIR)
- + error_msg_and_die("can't add '%s' to a non-directory", name);
- if(!*name)
- - errexit("bad name '%s' (not meaningful)", name);
- + error_msg_and_die("can't create an inode with an empty name");
- if(strchr(name, '/'))
- - errexit("bad name '%s' (contains a slash)", name);
- + error_msg_and_die("bad name '%s' (contains a slash)", name);
- nlen = strlen(name);
- reclen = sizeof(directory) + rndup(nlen, 4);
- if(reclen > BLOCKSIZE)
- - errexit("bad name '%s' (too long)", name);
- + error_msg_and_die("bad name '%s' (too long)", name);
- init_bw(fs, dnod, &bw);
- while((bk = walk_bw(fs, dnod, &bw, 0, 0)) != WALK_END) // for all blocks in dir
- {
- @@ -691,7 +1069,8 @@
- if((!d->d_inode) && (d->d_rec_len >= reclen))
- {
- d->d_inode = nod;
- - get_nod(fs, nod)->i_links_count++;
- + node = get_nod(fs, nod);
- + node->i_links_count++;
- d->d_name_len = nlen;
- strncpy(d->d_name, name, nlen);
- return;
- @@ -705,7 +1084,8 @@
- d = (directory*) (((int8*)d) + d->d_rec_len);
- d->d_rec_len = reclen;
- d->d_inode = nod;
- - get_nod(fs, nod)->i_links_count++;
- + node = get_nod(fs, nod);
- + node->i_links_count++;
- d->d_name_len = nlen;
- strncpy(d->d_name, name, nlen);
- return;
- @@ -716,7 +1096,8 @@
- b = get_workblk();
- d = (directory*)b;
- d->d_inode = nod;
- - get_nod(fs, nod)->i_links_count++;
- + node = get_nod(fs, nod);
- + node->i_links_count++;
- d->d_rec_len = BLOCKSIZE;
- d->d_name_len = nlen;
- strncpy(d->d_name, name, nlen);
- @@ -726,7 +1107,7 @@
- }
-
- // find an entry in a directory
- -uint32 find_dir(filesystem *fs, uint32 nod, const char * name)
- +static uint32 find_dir(filesystem *fs, uint32 nod, const char * name)
- {
- blockwalker bw;
- uint32 bk;
- @@ -745,9 +1126,9 @@
- }
-
- // find the inode of a full path
- -uint32 find_path(filesystem *fs, uint32 nod, const char * name)
- +static uint32 find_path(filesystem *fs, uint32 nod, const char * name)
- {
- - char *p, *n, *n2 = strdup(name);
- + char *p, *n, *n2 = xstrdup(name);
- n = n2;
- while(*n == '/')
- {
- @@ -769,28 +1150,62 @@
- return nod;
- }
-
- -// make a full-fledged directory (i.e. with "." & "..")
- -uint32 mkdir_fs(filesystem *fs, uint32 parent_nod, const char *name, uint32 mode)
- +// create a simple inode
- +static uint32 mknod_fs(filesystem *fs, uint32 parent_nod, const char *name, uint32 mode, uint16 uid, uint16 gid, uint8 major, uint8 minor, uint32 ctime, uint32 mtime)
- {
- uint32 nod;
- + inode *node;
- if((nod = find_dir(fs, parent_nod, name)))
- - return nod;
- - nod = alloc_nod(fs);
- - get_nod(fs, nod)->i_mode = FM_IFDIR | mode;
- - add2dir(fs, parent_nod, nod, name);
- - add2dir(fs, nod, nod, ".");
- - add2dir(fs, nod, parent_nod, "..");
- - fs->gd.bg_used_dirs_count++;
- + {
- + node = get_nod(fs, nod);
- + if((node->i_mode & FM_IFMT) != (mode & FM_IFMT))
- + error_msg_and_die("node '%s' already exists and isn't of the same type", name);
- + node->i_mode = mode;
- + }
- + else
- + {
- + nod = alloc_nod(fs);
- + node = get_nod(fs, nod);
- + node->i_mode = mode;
- + add2dir(fs, parent_nod, nod, name);
- + switch(mode & FM_IFMT)
- + {
- + case FM_IFLNK:
- + mode = FM_IFLNK | FM_IRWXU | FM_IRWXG | FM_IRWXO;
- + break;
- + case FM_IFBLK:
- + case FM_IFCHR:
- + ((uint8*)get_nod(fs, nod)->i_block)[0] = minor;
- + ((uint8*)get_nod(fs, nod)->i_block)[1] = major;
- + break;
- + case FM_IFDIR:
- + add2dir(fs, nod, nod, ".");
- + add2dir(fs, nod, parent_nod, "..");
- + fs->gd[GRP_GROUP_OF_INODE(fs,nod)].bg_used_dirs_count++;
- + break;
- + }
- + }
- + node->i_uid = uid;
- + node->i_gid = gid;
- + node->i_atime = mtime;
- + node->i_ctime = ctime;
- + node->i_mtime = mtime;
- return nod;
- }
-
- +// make a full-fledged directory (i.e. with "." & "..")
- +static inline uint32 mkdir_fs(filesystem *fs, uint32 parent_nod, const char *name, uint32 mode,
- + uid_t uid, gid_t gid, uint32 ctime, uint32 mtime)
- +{
- + return mknod_fs(fs, parent_nod, name, mode|FM_IFDIR, uid, gid, 0, 0, ctime, mtime);
- +}
- +
- // make a symlink
- -uint32 mklink_fs(filesystem *fs, uint32 parent_nod, const char *name, size_t size, uint8 * b)
- +static uint32 mklink_fs(filesystem *fs, uint32 parent_nod, const char *name, size_t size, uint8 *b, uid_t uid, gid_t gid, uint32 ctime, uint32 mtime)
- {
- - uint32 nod = alloc_nod(fs);
- - get_nod(fs, nod)->i_mode = FM_IFLNK | FM_IRWXU | FM_IRWXG | FM_IRWXO;
- + uint32 nod = mknod_fs(fs, parent_nod, name, FM_IFLNK | FM_IRWXU | FM_IRWXG | FM_IRWXO, uid, gid, 0, 0, ctime, mtime);
- + truncate_nod(fs, nod);
- get_nod(fs, nod)->i_size = size;
- - add2dir(fs, parent_nod, nod, name);
- if(size <= 4 * (EXT2_TIND_BLOCK+1))
- {
- strncpy((char*)get_nod(fs, nod)->i_block, (char*)b, size);
- @@ -801,228 +1216,361 @@
- }
-
- // make a file from a FILE*
- -uint32 mkfile_fs(filesystem *fs, uint32 parent_nod, const char *name, uint32 mode, size_t size, FILE *f)
- +static uint32 mkfile_fs(filesystem *fs, uint32 parent_nod, const char *name, uint32 mode, size_t size, FILE *f, uid_t uid, gid_t gid, uint32 ctime, uint32 mtime)
- {
- uint8 * b;
- - uint32 nod = alloc_nod(fs);
- - get_nod(fs, nod)->i_mode = FM_IFREG | mode;
- + uint32 nod = mknod_fs(fs, parent_nod, name, mode|FM_IFREG, uid, gid, 0, 0, ctime, mtime);
- + truncate_nod(fs, nod);
- get_nod(fs, nod)->i_size = size;
- - add2dir(fs, parent_nod, nod, name);
- if(!(b = (uint8*)malloc(rndup(size, BLOCKSIZE))))
- - errexit("not enough mem to read file '%s'", name);
- + error_msg_and_die("not enough mem to read file '%s'", name);
- memset(b, 0,rndup(size, BLOCKSIZE));
- if(f)
- - fread(b, size, 1, f);
- + fread(b, size, 1, f); // FIXME: ugly. use mmap() ...
- else
- - memset(b, 0, size);
- + memset(b, 0, size); // .. or handle b = 0
- extend_blk(fs, nod, b, rndup(size, BLOCKSIZE) / BLOCKSIZE);
- free(b);
- return nod;
- }
-
- // retrieves a mode info from a struct stat
- -uint32 get_mode(struct stat *st)
- +static uint32 get_mode(struct stat *st)
- {
- uint32 mode = 0;
- +
- if(st->st_mode & S_IRUSR)
- - mode |= FM_IRUSR | FM_IRGRP | FM_IROTH;
- + mode |= FM_IRUSR;
- if(st->st_mode & S_IWUSR)
- - mode |= FM_IWUSR | FM_IWGRP | FM_IWOTH;
- + mode |= FM_IWUSR;
- if(st->st_mode & S_IXUSR)
- - mode |= FM_IXUSR | FM_IXGRP | FM_IXOTH;
- + mode |= FM_IXUSR;
- + if(st->st_mode & S_IRGRP)
- + mode |= FM_IRGRP;
- + if(st->st_mode & S_IWGRP)
- + mode |= FM_IWGRP;
- + if(st->st_mode & S_IXGRP)
- + mode |= FM_IXGRP;
- + if(st->st_mode & S_IROTH)
- + mode |= FM_IROTH;
- + if(st->st_mode & S_IWOTH)
- + mode |= FM_IWOTH;
- + if(st->st_mode & S_IXOTH)
- + mode |= FM_IXOTH;
- + if(st->st_mode & S_ISUID)
- + mode |= FM_ISUID;
- + if(st->st_mode & S_ISGID)
- + mode |= FM_ISGID;
- + if(st->st_mode & S_ISVTX)
- + mode |= FM_ISVTX;
- return mode;
- }
-
- -// retrieves a mode info from a string
- -uint32 get_modestr(const char *p)
- -{
- - uint32 mode = 0;
- - if(p[0] == 'r')
- - mode |= FM_IRUSR | FM_IRGRP | FM_IROTH;
- - if(p[1] == 'w')
- - mode |= FM_IWUSR | FM_IWGRP | FM_IWOTH;
- - if(p[2] == 'x' || p[2] == 's')
- - mode |= FM_IXUSR | FM_IXGRP | FM_IXOTH;
- - return mode;
- -}
- -
- -// basename of a path - free me
- -char * basename(const char * fullpath)
- -{
- - char * p = strrchr(fullpath, '/');
- - return strdup(p ? p + 1 : fullpath);
- -}
- -
- -// dirname of a path - free me
- -char * dirname(const char * fullpath)
- -{
- - char * p, * n = strdup(fullpath);
- - if((p = strrchr(n, '/')))
- - *(p+1) = 0;
- - else
- - *n = 0;
- - return n;
- -}
- +// add or fixup entries to the filesystem from a text file
- +/* device table entries take the form of:
- + <path> <type> <mode> <uid> <gid> <major> <minor> <start> <inc> <count>
- + /dev/mem c 640 0 0 1 1 0 0 -
- +
- + type can be one of:
- + f A regular file
- + d Directory
- + c Character special device file
- + b Block special device file
- + p Fifo (named pipe)
- +
- + I don't bother with symlinks (permissions are irrelevant), hard
- + links (special cases of regular files), or sockets (why bother).
- +
- + Regular files must exist in the target root directory. If a char,
- + block, fifo, or directory does not exist, it will be created.
- +*/
- +
- +static void add2fs_from_file(filesystem *fs, uint32 this_nod, FILE * fh, int squash_uids, int squash_perms, struct stats *stats)
- +{
- + unsigned long mode, uid, gid, major, minor;
- + unsigned long start, increment, count;
- + uint32 nod, ctime, mtime;
- + char *c, type, *path = NULL, *path2 = NULL, *dir, *name, *line = NULL;
- + size_t len;
- + struct stat st;
- + int nbargs, lineno = 0;
-
- -// adds entries to the filesystem from a text file
- -void add2fs_from_file(filesystem *fs, uint32 this_nod, FILE * fh)
- -{
- - uint32 mode;
- - uint32 nod, nod2;
- - char cmod[11], *path, *name, *dir;
- - int major, minor;
- - while(fscanf(fh, "%10s", cmod))
- - {
- - if(feof(fh))
- - break;
- - mode = get_modestr(cmod + 1);
- - switch(*cmod)
- + fstat(fileno(fh), &st);
- + ctime = st.st_ctime;
- + mtime = st.st_mtime;
- + while(getline(&line, &len, fh) >= 0)
- + {
- + mode = uid = gid = major = minor = 0;
- + start = 0; increment = 1; count = 0;
- + lineno++;
- + if((c = strchr(line, '#')))
- + *c = 0;
- + free(path); path = NULL;
- + free(path2); path2 = NULL;
- + nbargs = sscanf (line, "%" SCANF_PREFIX "s %c %lo %lu %lu %lu %lu %lu %lu %lu",
- + SCANF_STRING(path), &type, &mode, &uid, &gid, &major, &minor,
- + &start, &increment, &count);
- + if(nbargs < 3)
- {
- - case 'd':
- - fscanf(fh, "%" SCANF_PREFIX "s\n", SCANF_STRING(path));
- - break;
- - case 'c':
- - mode |= FM_IFCHR;
- - fscanf(fh, "%i, %i %" SCANF_PREFIX "s\n", &major, &minor, SCANF_STRING(path));
- - break;
- - case 'b':
- - mode |= FM_IFBLK;
- - fscanf(fh, "%i, %i %" SCANF_PREFIX "s\n", &major, &minor, SCANF_STRING(path));
- - break;
- - case '#':
- - while(fgetc(fh) != '\n');
- - continue;
- - default:
- - errexit("malformed text input file");
- + if(nbargs > 0)
- + error_msg("device table line %d skipped: bad format for entry '%s'", lineno, path);
- + continue;
- }
- - name = basename(path);
- - dir = dirname(path);
- - free(path);
- - if(!(nod = find_path(fs, this_nod, dir)))
- - errexit("can't find directory '%s' to create '%s''", dir, name);
- - free(dir);
- - if((!strcmp(name, ".")) || (!strcmp(name, "..")))
- + if(stats)
- {
- - free(name);
- - continue;
- + stats->ninodes += count ? count : 1;
- }
- - switch(*cmod)
- + else
- {
- - case 'd':
- - mkdir_fs(fs, nod, name, mode);
- - break;
- - case 'c':
- - case 'b':
- - nod2 = alloc_nod(fs);
- - get_nod(fs, nod2)->i_mode = mode;
- - ((uint8*)get_nod(fs, nod2)->i_block)[0] = minor;
- - ((uint8*)get_nod(fs, nod2)->i_block)[1] = major;
- - add2dir(fs, nod, nod2, name);
- - break;
- + if(squash_uids)
- + uid = gid = 0;
- + if(squash_perms)
- + mode &= ~(FM_IRWXG | FM_IRWXO);
- + mode &= FM_IMASK;
- + path2 = strdup(path);
- + name = basename(path);
- + dir = dirname(path2);
- + if(!(nod = find_path(fs, this_nod, dir)))
- + {
- + error_msg("device table line %d skipped: can't find directory '%s' to create '%s''", lineno, dir, name);
- + continue;
- + }
- + if((!strcmp(name, ".")) || (!strcmp(name, "..")))
- + {
- + error_msg("device table line %d skipped", lineno);
- + continue;
- + }
- +
- + switch (type)
- + {
- + case 'd':
- + mode |= FM_IFDIR;
- + break;
- + case 'f':
- + mode |= FM_IFREG;
- + break;
- + case 'p':
- + mode |= FM_IFIFO;
- + break;
- + case 'c':
- + mode |= FM_IFCHR;
- + break;
- + case 'b':
- + mode |= FM_IFBLK;
- + break;
- + default:
- + error_msg("device table line %d skipped: bad type '%c' for entry '%s'", lineno, type, name);
- + continue;
- + }
- + if(count > 0)
- + {
- + char *dname;
- + unsigned i, len;
- + len = strlen(name) + 10;
- + dname = malloc(len + 1);
- + for(i = start; i < count; i++)
- + {
- + snprintf(dname, len, "%s%u", name, i);
- + mknod_fs(fs, nod, dname, mode, uid, gid, major, minor + (i * increment - start), ctime, mtime);
- + }
- + free(dname);
- + }
- + else
- + mknod_fs(fs, nod, name, mode, uid, gid, major, minor, ctime, mtime);
- }
- - free(name);
- }
- + free(line);
- + free(path);
- + free(path2);
- }
-
- // adds a tree of entries to the filesystem from current dir
- -void add2fs_from_dir(filesystem *fs, uint32 this_nod)
- +static void add2fs_from_dir(filesystem *fs, uint32 this_nod, int squash_uids, int squash_perms, struct stats *stats)
- {
- uint32 nod;
- + uint32 uid, gid, mode, ctime, mtime;
- + const char *name;
- FILE *fh;
- DIR *dh;
- struct dirent *dent;
- struct stat st;
- uint8 *b;
- if(!(dh = opendir(".")))
- - pexit(".");
- + perror_msg_and_die(".");
- while((dent = readdir(dh)))
- {
- if((!strcmp(dent->d_name, ".")) || (!strcmp(dent->d_name, "..")))
- continue;
- lstat(dent->d_name, &st);
- - switch(st.st_mode & S_IFMT)
- - {
- - case S_IFCHR:
- - case S_IFBLK:
- - nod = alloc_nod(fs);
- - get_nod(fs, nod)->i_mode = (((st.st_mode & S_IFMT) == S_IFCHR) ? FM_IFCHR : FM_IFBLK) | get_mode(&st);
- - ((uint8*)get_nod(fs, nod)->i_block)[0] = (st.st_rdev & 0xff);
- - ((uint8*)get_nod(fs, nod)->i_block)[1] = (st.st_rdev >> 8);
- - add2dir(fs, this_nod, nod, dent->d_name);
- - break;
- - case S_IFLNK:
- - if(!(b = (uint8*)malloc(rndup(st.st_size, BLOCKSIZE))))
- - errexit("out of memory");
- - if(readlink(dent->d_name, (char*)b, st.st_size) < 0)
- - pexit(dent->d_name);
- - mklink_fs(fs, this_nod, dent->d_name, st.st_size, b);
- - free(b);
- - break;
- - case S_IFREG:
- - if(!(fh = fopen(dent->d_name, "r")))
- - pexit(dent->d_name);
- - mkfile_fs(fs, this_nod, dent->d_name, get_mode(&st), st.st_size, fh);
- - fclose(fh);
- - break;
- - case S_IFDIR:
- - nod = mkdir_fs(fs, this_nod, dent->d_name, get_mode(&st));
- - if(chdir(dent->d_name) < 0)
- - pexit(dent->d_name);
- - add2fs_from_dir(fs, nod);
- - chdir("..");
- - break;
- - default:
- - fprintf(stderr, "ignoring entry %s", dent->d_name);
- - }
- + uid = st.st_uid;
- + gid = st.st_gid;
- + ctime = st.st_ctime;
- + mtime = st.st_mtime;
- + name = dent->d_name;
- + mode = get_mode(&st);
- + if(squash_uids)
- + uid = gid = 0;
- + if(squash_perms)
- + mode &= ~(FM_IRWXG | FM_IRWXO);
- + if(stats)
- + switch(st.st_mode & S_IFMT)
- + {
- + case S_IFLNK:
- + case S_IFREG:
- + if((st.st_mode & S_IFMT) == S_IFREG || st.st_size > 4 * (EXT2_TIND_BLOCK+1))
- + stats->nblocks += (st.st_size + BLOCKSIZE - 1) / BLOCKSIZE;
- + case S_IFCHR:
- + case S_IFBLK:
- + case S_IFIFO:
- + stats->ninodes++;
- + break;
- + case S_IFDIR:
- + stats->ninodes++;
- + if(chdir(dent->d_name) < 0)
- + perror_msg_and_die(dent->d_name);
- + add2fs_from_dir(fs, nod, squash_uids, squash_perms, stats);
- + chdir("..");
- + break;
- + default:
- + break;
- + }
- + else
- + switch(st.st_mode & S_IFMT)
- + {
- + case S_IFCHR:
- + mknod_fs(fs, this_nod, name, mode|FM_IFCHR, uid, gid, st.st_rdev >> 8, st.st_rdev & 0xff, ctime, mtime);
- + break;
- + case S_IFBLK:
- + mknod_fs(fs, this_nod, name, mode|FM_IFBLK, uid, gid, st.st_rdev >> 8, st.st_rdev & 0xff, ctime, mtime);
- + break;
- + case S_IFIFO:
- + mknod_fs(fs, this_nod, name, mode|FM_IFIFO, uid, gid, 0, 0, ctime, mtime);
- + break;
- + case S_IFLNK:
- + b = xreadlink(dent->d_name);
- + mklink_fs(fs, this_nod, name, st.st_size, b, uid, gid, ctime, mtime);
- + free(b);
- + break;
- + case S_IFREG:
- + fh = xfopen(dent->d_name, "r");
- + mkfile_fs(fs, this_nod, name, mode, st.st_size, fh, uid, gid, ctime, mtime);
- + fclose(fh);
- + break;
- + case S_IFDIR:
- + nod = mkdir_fs(fs, this_nod, name, mode, uid, gid, ctime, mtime);
- + if(chdir(dent->d_name) < 0)
- + perror_msg_and_die(name);
- + add2fs_from_dir(fs, nod, squash_uids, squash_perms, stats);
- + chdir("..");
- + break;
- + default:
- + error_msg("ignoring entry %s", name);
- + }
- }
- closedir(dh);
- }
-
- // endianness swap of x-indirect blocks
- -void swap_goodblocks(filesystem *fs, inode *nod)
- +static void swap_goodblocks(filesystem *fs, inode *nod)
- {
- - int i;
- + int i,j,done=0;
- + uint32 *b,*b2;
- +
- int nblk = nod->i_blocks / INOBLK;
- - if((nod->i_size && !nblk) || (nod->i_mode & (FM_IFBLK | FM_IFCHR)))
- + if((nod->i_size && !nblk) || ((nod->i_mode & FM_IFBLK) == FM_IFBLK) || ((nod->i_mode & FM_IFCHR) == FM_IFCHR))
- for(i = 0; i <= EXT2_TIND_BLOCK; i++)
- nod->i_block[i] = swab32(nod->i_block[i]);
- if(nblk <= EXT2_IND_BLOCK)
- return;
- swap_block(get_blk(fs, nod->i_block[EXT2_IND_BLOCK]));
- - if(nblk <= EXT2_IND_BLOCK + BLOCKSIZE/4)
- + if(nblk <= EXT2_DIND_BLOCK + BLOCKSIZE/4)
- return;
- + /* Currently this will fail b'cos the number of blocks as stored
- + in i_blocks also includes the indirection blocks (see
- + walk_bw). But this function assumes that i_blocks only
- + stores the count of data blocks ( Actually according to
- + "Understanding the Linux Kernel" (Table 17-3 p502 1st Ed)
- + i_blocks IS supposed to store the count of data blocks). so
- + with a file of size 268K nblk would be 269.The above check
- + will be false even though double indirection hasn't been
- + started.This is benign as 0 means block 0 which has been
- + zeroed out and therefore points back to itself from any offset
- + */
- + // FIXME: I have fixed that, but I have the feeling the rest of
- + // ths function needs to be fixed for the same reasons - Xav
- + assert(nod->i_block[EXT2_DIND_BLOCK] != 0);
- for(i = 0; i < BLOCKSIZE/4; i++)
- - if(nblk > EXT2_IND_BLOCK + BLOCKSIZE/4 + i)
- + if(nblk > EXT2_IND_BLOCK + BLOCKSIZE/4 + (BLOCKSIZE/4)*i )
- swap_block(get_blk(fs, ((uint32*)get_blk(fs, nod->i_block[EXT2_DIND_BLOCK]))[i]));
- swap_block(get_blk(fs, nod->i_block[EXT2_DIND_BLOCK]));
- if(nblk <= EXT2_IND_BLOCK + BLOCKSIZE/4 + BLOCKSIZE/4 * BLOCKSIZE/4)
- return;
- - errexit("too big file on the filesystem");
- + /* Adding support for triple indirection */
- + b = (uint32*)get_blk(fs,nod->i_block[EXT2_TIND_BLOCK]);
- + for(i=0;i < BLOCKSIZE/4 && !done ; i++) {
- + b2 = (uint32*)get_blk(fs,b[i]);
- + for(j=0; j<BLOCKSIZE/4;j++) {
- + if (nblk > ( EXT2_IND_BLOCK + BLOCKSIZE/4 +
- + (BLOCKSIZE/4)*(BLOCKSIZE/4) +
- + i*(BLOCKSIZE/4)*(BLOCKSIZE/4) +
- + j*(BLOCKSIZE/4)) )
- + swap_block(get_blk(fs,b2[j]));
- + else {
- + done = 1;
- + break;
- + }
- + }
- + swap_block((uint8 *)b2);
- + }
- + swap_block((uint8 *)b);
- + return;
- }
-
- -void swap_badblocks(filesystem *fs, inode *nod)
- +static void swap_badblocks(filesystem *fs, inode *nod)
- {
- - int i;
- + int i,j,done=0;
- + uint32 *b,*b2;
- +
- int nblk = nod->i_blocks / INOBLK;
- - if((nod->i_size && !nblk) || (nod->i_mode & (FM_IFBLK | FM_IFCHR)))
- + if((nod->i_size && !nblk) || ((nod->i_mode & FM_IFBLK) == FM_IFBLK) || ((nod->i_mode & FM_IFCHR) == FM_IFCHR))
- for(i = 0; i <= EXT2_TIND_BLOCK; i++)
- nod->i_block[i] = swab32(nod->i_block[i]);
- if(nblk <= EXT2_IND_BLOCK)
- return;
- swap_block(get_blk(fs, nod->i_block[EXT2_IND_BLOCK]));
- - if(nblk <= EXT2_IND_BLOCK + BLOCKSIZE/4)
- + if(nblk <= EXT2_DIND_BLOCK + BLOCKSIZE/4)
- return;
- + /* See comment in swap_goodblocks */
- + assert(nod->i_block[EXT2_DIND_BLOCK] != 0);
- swap_block(get_blk(fs, nod->i_block[EXT2_DIND_BLOCK]));
- for(i = 0; i < BLOCKSIZE/4; i++)
- - if(nblk > EXT2_IND_BLOCK + BLOCKSIZE/4 + i)
- + if(nblk > EXT2_IND_BLOCK + BLOCKSIZE/4 + (BLOCKSIZE/4)*i )
- swap_block(get_blk(fs, ((uint32*)get_blk(fs, nod->i_block[EXT2_DIND_BLOCK]))[i]));
- if(nblk <= EXT2_IND_BLOCK + BLOCKSIZE/4 + BLOCKSIZE/4 * BLOCKSIZE/4)
- return;
- - errexit("too big file on the filesystem");
- + /* Adding support for triple indirection */
- + b = (uint32*)get_blk(fs,nod->i_block[EXT2_TIND_BLOCK]);
- + swap_block((uint8 *)b);
- + for(i=0;i < BLOCKSIZE/4 && !done ; i++) {
- + b2 = (uint32*)get_blk(fs,b[i]);
- + swap_block((uint8 *)b2);
- + for(j=0; j<BLOCKSIZE/4;j++) {
- + if (nblk > ( EXT2_IND_BLOCK + BLOCKSIZE/4 +
- + (BLOCKSIZE/4)*(BLOCKSIZE/4) +
- + i*(BLOCKSIZE/4)*(BLOCKSIZE/4) +
- + j*(BLOCKSIZE/4)) )
- + swap_block(get_blk(fs,b2[j]));
- + else {
- + done = 1;
- + break;
- + }
- + }
- + }
- + return;
- }
-
- // endianness swap of the whole filesystem
- -void swap_goodfs(filesystem *fs)
- +static void swap_goodfs(filesystem *fs)
- {
- int i;
- for(i = 1; i < fs->sb.s_inodes_count; i++)
- @@ -1045,15 +1593,17 @@
- swap_goodblocks(fs, nod);
- swap_nod(nod);
- }
- - swap_gd(&fs->gd);
- + for(i=0;i<GRP_NBGROUPS(fs);i++)
- + swap_gd(&(fs->gd[i]));
- swap_sb(&fs->sb);
- }
-
- -void swap_badfs(filesystem *fs)
- +static void swap_badfs(filesystem *fs)
- {
- int i;
- swap_sb(&fs->sb);
- - swap_gd(&fs->gd);
- + for(i=0;i<GRP_NBGROUPS(fs);i++)
- + swap_gd(&(fs->gd[i]));
- for(i = 1; i < fs->sb.s_inodes_count; i++)
- {
- inode *nod = get_nod(fs, i);
- @@ -1077,60 +1627,123 @@
- }
-
- // initialize an empty filesystem
- -filesystem * init_fs(int nbblocks, int nbinodes, int nbresrvd, int holes)
- +static filesystem * init_fs(int nbblocks, int nbinodes, int nbresrvd, int holes)
- {
- int i;
- filesystem *fs;
- directory *d;
- uint8 * b;
- uint32 nod;
- + uint32 nbgroups,nbinodes_per_group,overhead_per_group,free_blocks,
- + free_blocks_per_group,nbblocks_per_group;
- + uint32 gd,itbl,ibmpos,bbmpos,itblpos;
- + int j;
- + uint8 *bbm,*ibm;
- + inode *itab0;
- + uint32 now = time(NULL);
-
- if(nbblocks < 16) // totally arbitrary
- - errexit("too small filesystem");
- - if(nbblocks >BLOCKS_PER_GROUP) // I build only one group
- - errexit("too big filesystem");
- + error_msg_and_die("too small filesystem");
- +
- + /* nbblocks is the total number of blocks in the filesystem. First
- + * calculate the size of each group assuming each group has
- + * BLOCKS_PER_GROUP blocks (which is the maximum). Then recalculate
- + * blocks per group so that each group (except possibly the last one)
- + * has the same number of blocks. nbinodes is the total number of
- + * inodes in the system. These are divided between all groups.
- + * Then calculate the overhead blocks - inode table blocks, bitmap
- + * blocks, group descriptor blocks etc.
- + */
- +
- + nbgroups = (nbblocks + BLOCKS_PER_GROUP - 1) / BLOCKS_PER_GROUP;
- + nbblocks_per_group = rndup((nbblocks + nbgroups - 1)/nbgroups, 8);
- + nbinodes_per_group = rndup((nbinodes + nbgroups - 1)/nbgroups,
- + (BLOCKSIZE/sizeof(inode)));
- + if (nbinodes_per_group < 16)
- + nbinodes_per_group = 16; //minimum number b'cos the first 10 are reserved
- +
- + gd = rndup(nbgroups*sizeof(groupdescriptor),BLOCKSIZE)/BLOCKSIZE;
- + itbl = nbinodes_per_group * sizeof(inode)/BLOCKSIZE;
- + overhead_per_group = 3 /*sb,ibm,bbm*/ + itbl + gd;
- + free_blocks = nbblocks - overhead_per_group*nbgroups - 1 /*boot block*/;
- + free_blocks_per_group = nbblocks_per_group - overhead_per_group;
- +
- if(!(fs = (filesystem*)calloc(nbblocks, BLOCKSIZE)))
- - errexit("not enough memory for filesystem");
- + error_msg_and_die("not enough memory for filesystem");
-
- // create the superblock for an empty filesystem
- - fs->sb.s_inodes_count = rndup(nbinodes, BLOCKSIZE/sizeof(inode));
- + fs->sb.s_inodes_count = nbinodes_per_group * nbgroups;
- fs->sb.s_blocks_count = nbblocks;
- fs->sb.s_r_blocks_count = nbresrvd;
- - fs->sb.s_free_blocks_count = nbblocks;
- + fs->sb.s_free_blocks_count = free_blocks;
- fs->sb.s_free_inodes_count = fs->sb.s_inodes_count - EXT2_FIRST_INO + 1;
- fs->sb.s_first_data_block = (BLOCKSIZE == 1024);
- fs->sb.s_log_block_size = BLOCKSIZE >> 11;
- fs->sb.s_log_frag_size = BLOCKSIZE >> 11;
- - fs->sb.s_blocks_per_group = BLOCKS_PER_GROUP;
- - fs->sb.s_frags_per_group = BLOCKS_PER_GROUP;
- - fs->sb.s_inodes_per_group = fs->sb.s_inodes_count;
- + fs->sb.s_blocks_per_group = nbblocks_per_group;
- + fs->sb.s_frags_per_group = nbblocks_per_group;
- + fs->sb.s_inodes_per_group = nbinodes_per_group;
- fs->sb.s_magic = EXT2_MAGIC_NUMBER;
-
- // set up groupdescriptors
- - fs->sb.s_free_blocks_count -= 5 + fs->sb.s_inodes_count * sizeof(inode) / BLOCKSIZE;
- - fs->gd.bg_free_blocks_count = fs->sb.s_free_blocks_count;
- - fs->gd.bg_free_inodes_count = fs->sb.s_free_inodes_count;
- - fs->gd.bg_used_dirs_count = 1;
- - fs->gd.bg_block_bitmap = 3;
- - fs->gd.bg_inode_bitmap = 4;
- - fs->gd.bg_inode_table = 5;
- -
- - // mark non-filesystem blocks and inodes as allocated
- - for(i = fs->sb.s_blocks_count; i <= BLOCKSIZE * 8; i++)
- - allocate(fs->bbm, i);
- - for(i = fs->sb.s_inodes_count + 1; i <= BLOCKSIZE * 8; i++)
- - allocate(fs->ibm, i);
- -
- - // mark system blocsk and inodes as allocated
- - for(i = 1; i <= 4 + fs->sb.s_inodes_count * sizeof(inode) / BLOCKSIZE; i++)
- - allocate(fs->bbm, i);
- - for(i = 1; i < EXT2_FIRST_INO; i++)
- - allocate(fs->ibm, i);
- + for(i = 0,bbmpos=2+gd,ibmpos=3+gd,itblpos =4+gd;
- + i<nbgroups;
- + i++, bbmpos += nbblocks_per_group,ibmpos += nbblocks_per_group,
- + itblpos += nbblocks_per_group) {
- +
- + if(free_blocks > free_blocks_per_group) {
- + fs->gd[i].bg_free_blocks_count = free_blocks_per_group;
- + free_blocks -= free_blocks_per_group;
- + } else {
- + fs->gd[i].bg_free_blocks_count = free_blocks;
- + free_blocks = 0; // this is the last block group
- + }
- + if(i)
- + fs->gd[i].bg_free_inodes_count = nbinodes_per_group;
- + else
- + fs->gd[i].bg_free_inodes_count = nbinodes_per_group -
- + EXT2_FIRST_INO + 2;
- + fs->gd[i].bg_used_dirs_count = 0;
- + fs->gd[i].bg_block_bitmap = bbmpos;
- + fs->gd[i].bg_inode_bitmap = ibmpos;
- + fs->gd[i].bg_inode_table = itblpos;
- + }
- +
- + /* Mark non-filesystem blocks and inodes as allocated */
- + /* Mark system blocks and inodes as allocated */
- + for(i = 0; i<nbgroups;i++) {
- +
- + /* Block bitmap */
- + bbm = get_blk(fs,fs->gd[i].bg_block_bitmap);
- + //non-filesystem blocks
- + for(j = fs->gd[i].bg_free_blocks_count
- + + overhead_per_group + 1; j <= BLOCKSIZE * 8; j++)
- + allocate(bbm, j);
- + //system blocks
- + for(j = 1; j <= overhead_per_group; j++)
- + allocate(bbm, j);
- +
- + /* Inode bitmap */
- + ibm = get_blk(fs,fs->gd[i].bg_inode_bitmap);
- + //non-filesystem inodes
- + for(j = fs->sb.s_inodes_per_group+1; j <= BLOCKSIZE * 8; j++)
- + allocate(ibm, j);
- + //system inodes
- + if(i == 0)
- + for(j = 1; j < EXT2_FIRST_INO; j++)
- + allocate(ibm, j);
- + }
-
- // make root inode and directory
- - fs->itab[EXT2_ROOT_INO-1].i_mode = FM_IFDIR | FM_IRWXU | FM_IRWXG | FM_IRWXO;
- - fs->itab[EXT2_ROOT_INO-1].i_size = BLOCKSIZE;
- - fs->itab[EXT2_ROOT_INO-1].i_links_count = 2;
- + /* We have groups now. Add the root filesystem in group 0 */
- + /* Also increment the directory count for group 0 */
- + fs->gd[0].bg_free_inodes_count--;
- + fs->gd[0].bg_used_dirs_count = 1;
- + itab0 = (inode *)get_blk(fs,fs->gd[0].bg_inode_table);
- + itab0[EXT2_ROOT_INO-1].i_mode = FM_IFDIR | FM_IRWXU | FM_IRGRP | FM_IROTH | FM_IXGRP | FM_IXOTH;
- + itab0[EXT2_ROOT_INO-1].i_size = BLOCKSIZE;
- + itab0[EXT2_ROOT_INO-1].i_links_count = 2;
- +
- b = get_workblk();
- d = (directory*)b;
- d->d_inode = EXT2_ROOT_INO;
- @@ -1147,9 +1760,14 @@
- // make lost+found directory and reserve blocks
- if(fs->sb.s_r_blocks_count)
- {
- - nod = mkdir_fs(fs, EXT2_ROOT_INO, "lost+found", FM_IRWXU | FM_IRWXG | FM_IRWXO);
- + nod = mkdir_fs(fs, EXT2_ROOT_INO, "lost+found", FM_IRWXU, 0, 0, now, now);
- memset(b, 0, BLOCKSIZE);
- ((directory*)b)->d_rec_len = BLOCKSIZE;
- + /* We run into problems with e2fsck if directory lost+found grows
- + * bigger than this. Need to find out why this happens - sundar
- + */
- + if (fs->sb.s_r_blocks_count > fs->sb.s_blocks_count * MAX_RESERVED_BLOCKS )
- + fs->sb.s_r_blocks_count = fs->sb.s_blocks_count * MAX_RESERVED_BLOCKS;
- for(i = 1; i < fs->sb.s_r_blocks_count; i++)
- extend_blk(fs, nod, b, 1);
- get_nod(fs, nod)->i_size = fs->sb.s_r_blocks_count * BLOCKSIZE;
- @@ -1168,36 +1786,34 @@
- }
-
- // loads a filesystem from disk
- -filesystem * load_fs(FILE * fh, int swapit)
- +static filesystem * load_fs(FILE * fh, int swapit)
- {
- size_t fssize;
- filesystem *fs;
- if((fseek(fh, 0, SEEK_END) < 0) || ((fssize = ftell(fh)) < 0))
- - pexit("input filesystem image");
- + perror_msg_and_die("input filesystem image");
- rewind(fh);
- fssize = (fssize + BLOCKSIZE - 1) / BLOCKSIZE;
- if(fssize < 16) // totally arbitrary
- - errexit("too small filesystem");
- - if(fssize > BLOCKS_PER_GROUP) // I build only one group
- - errexit("too big filesystem");
- + error_msg_and_die("too small filesystem");
- if(!(fs = (filesystem*)calloc(fssize, BLOCKSIZE)))
- - errexit("not enough memory for filesystem");
- + error_msg_and_die("not enough memory for filesystem");
- if(fread(fs, BLOCKSIZE, fssize, fh) != fssize)
- - pexit("input filesystem image");
- + perror_msg_and_die("input filesystem image");
- if(swapit)
- swap_badfs(fs);
- if(fs->sb.s_rev_level || (fs->sb.s_magic != EXT2_MAGIC_NUMBER))
- - errexit("not a suitable ext2 filesystem");
- + error_msg_and_die("not a suitable ext2 filesystem");
- return fs;
- }
-
- -void free_fs(filesystem *fs)
- +static void free_fs(filesystem *fs)
- {
- free(fs);
- }
-
- // just walk through blocks list
- -void flist_blocks(filesystem *fs, uint32 nod, FILE *fh)
- +static void flist_blocks(filesystem *fs, uint32 nod, FILE *fh)
- {
- blockwalker bw;
- uint32 bk;
- @@ -1208,7 +1824,7 @@
- }
-
- // walk through blocks list
- -void list_blocks(filesystem *fs, uint32 nod)
- +static void list_blocks(filesystem *fs, uint32 nod)
- {
- int bn = 0;
- blockwalker bw;
- @@ -1221,7 +1837,7 @@
- }
-
- // saves blocks to FILE*
- -void write_blocks(filesystem *fs, uint32 nod, FILE* f)
- +static void write_blocks(filesystem *fs, uint32 nod, FILE* f)
- {
- blockwalker bw;
- uint32 bk;
- @@ -1230,15 +1846,15 @@
- while((bk = walk_bw(fs, nod, &bw, 0, 0)) != WALK_END)
- {
- if(fsize <= 0)
- - errexit("wrong size while saving inode %d", nod);
- + error_msg_and_die("wrong size while saving inode %d", nod);
- if(fwrite(get_blk(fs, bk), (fsize > BLOCKSIZE) ? BLOCKSIZE : fsize, 1, f) != 1)
- - errexit("error while saving inode %d", nod);
- + error_msg_and_die("error while saving inode %d", nod);
- fsize -= BLOCKSIZE;
- }
- }
-
- // hexdumps blocks to a FILE*
- -void hexdump_blocks(filesystem *fs, uint32 nod, FILE* f)
- +static void hexdump_blocks(filesystem *fs, uint32 nod, FILE* f)
- {
- blockwalker bw;
- uint32 bk;
- @@ -1250,7 +1866,7 @@
- {
- int i, j;
- if(fsize <= 0)
- - errexit("wrong size while saving inode %d", nod);
- + error_msg_and_die("wrong size while saving inode %d", nod);
- b = get_blk(fs, bk);
- for(i = 0; i < 64; i++)
- {
- @@ -1273,7 +1889,7 @@
- }
-
- // print block/char device minor and major
- -void print_dev(filesystem *fs, uint32 nod)
- +static void print_dev(filesystem *fs, uint32 nod)
- {
- int minor, major;
- minor = ((uint8*)get_nod(fs, nod)->i_block)[0];
- @@ -1282,7 +1898,7 @@
- }
-
- // print an inode as a directory
- -void print_dir(filesystem *fs, uint32 nod)
- +static void print_dir(filesystem *fs, uint32 nod)
- {
- blockwalker bw;
- uint32 bk;
- @@ -1306,7 +1922,7 @@
- }
-
- // print a symbolic link
- -void print_link(filesystem *fs, uint32 nod)
- +static void print_link(filesystem *fs, uint32 nod)
- {
- if(!get_nod(fs, nod)->i_blocks)
- printf("links to '%s'\n", (char*)get_nod(fs, nod)->i_block);
- @@ -1319,7 +1935,7 @@
- }
-
- // make a ls-like printout of permissions
- -void make_perms(uint32 mode, char perms[11])
- +static void make_perms(uint32 mode, char perms[11])
- {
- strcpy(perms, "----------");
- if(mode & FM_IRUSR)
- @@ -1378,7 +1994,7 @@
- }
-
- // print an inode
- -void print_inode(filesystem *fs, uint32 nod)
- +static void print_inode(filesystem *fs, uint32 nod)
- {
- char *s;
- char perms[11];
- @@ -1406,7 +2022,7 @@
- s = (nod >= EXT2_FIRST_INO) ? "normal" : "unknown reserved";
- }
- printf("inode %d (%s, %d links): ", nod, s, get_nod(fs, nod)->i_links_count);
- - if(!allocated(fs->ibm, nod))
- + if(!allocated(GRP_GET_INODE_BITMAP(fs,nod), GRP_IBM_OFFSET(fs,nod)))
- {
- printf("unallocated\n");
- return;
- @@ -1440,58 +2056,76 @@
- default:
- list_blocks(fs, nod);
- }
- + printf("Done with inode %d\n",nod);
- }
-
- // describes various fields in a filesystem
- -void print_fs(filesystem *fs)
- +static void print_fs(filesystem *fs)
- {
- int i;
- - printf("%d blocks (%d free, %d reserved), first data block: %d\n", fs->sb.s_blocks_count, fs->sb.s_free_blocks_count, fs->sb.s_r_blocks_count, fs->sb.s_first_data_block);
- - printf("%d inodes (%d free)\n", fs->sb.s_inodes_count, fs->sb.s_free_inodes_count);
- - printf("block size = %d, frag size = %d\n", fs->sb.s_log_block_size ? (fs->sb.s_log_block_size << 11) : 1024, fs->sb.s_log_frag_size ? (fs->sb.s_log_frag_size << 11) : 1024);
- - printf("%d blocks per group, %d frags per group, %d inodes per group\n", fs->sb.s_blocks_per_group, fs->sb.s_frags_per_group, fs->sb.s_inodes_per_group);
- - printf("block bitmap: block %d, inode bitmap: block %d, inode table: block %d\n", fs->gd.bg_block_bitmap, fs->gd.bg_inode_bitmap, fs->gd.bg_inode_table);
- - printf("block bitmap allocation:\n");
- - print_bm(fs->bbm, fs->sb.s_blocks_count);
- - printf("inode bitmap allocation:\n");
- - print_bm(fs->ibm, fs->sb.s_inodes_count);
- - for(i=1; i<=fs->sb.s_inodes_count; i++)
- - if(allocated(fs->ibm, i))
- - print_inode(fs, i);
- + uint8 *ibm;
- +
- + printf("%d blocks (%d free, %d reserved), first data block: %d\n",
- + fs->sb.s_blocks_count, fs->sb.s_free_blocks_count,
- + fs->sb.s_r_blocks_count, fs->sb.s_first_data_block);
- + printf("%d inodes (%d free)\n", fs->sb.s_inodes_count,
- + fs->sb.s_free_inodes_count);
- + printf("block size = %d, frag size = %d\n",
- + fs->sb.s_log_block_size ? (fs->sb.s_log_block_size << 11) : 1024,
- + fs->sb.s_log_frag_size ? (fs->sb.s_log_frag_size << 11) : 1024);
- + printf("number of groups: %d\n",GRP_NBGROUPS(fs));
- + printf("%d blocks per group,%d frags per group,%d inodes per group\n",
- + fs->sb.s_blocks_per_group, fs->sb.s_frags_per_group,
- + fs->sb.s_inodes_per_group);
- + printf("Size of inode table: %d blocks\n",
- + fs->sb.s_inodes_per_group * sizeof(inode)/BLOCKSIZE);
- + for (i = 0; i < GRP_NBGROUPS(fs); i++) {
- + printf("Group No: %d\n", i+1);
- + printf("block bitmap: block %d,inode bitmap: block %d, inode table: block %d\n",
- + fs->gd[i].bg_block_bitmap, fs->gd[i].bg_inode_bitmap,
- + fs->gd[i].bg_inode_table);
- + printf("block bitmap allocation:\n");
- + print_bm(GRP_GET_GROUP_BBM(fs, i),fs->sb.s_blocks_per_group);
- + printf("inode bitmap allocation:\n");
- + ibm = GRP_GET_GROUP_IBM(fs, i);
- + print_bm(ibm, fs->sb.s_inodes_per_group);
- + for (i = 1; i <= fs->sb.s_inodes_per_group; i++)
- + if (allocated(ibm, i))
- + print_inode(fs, i);
- + }
- }
-
- -void dump_fs(filesystem *fs, FILE * fh, int swapit)
- +static void dump_fs(filesystem *fs, FILE * fh, int swapit)
- {
- int nbblocks = fs->sb.s_blocks_count;
- fs->sb.s_reserved[200] = 0;
- if(swapit)
- swap_goodfs(fs);
- if(fwrite(fs, BLOCKSIZE, nbblocks, fh) < nbblocks)
- - pexit("output filesystem image");
- + perror_msg_and_die("output filesystem image");
- if(swapit)
- swap_badfs(fs);
- }
-
- -void showhelp(void)
- +static void showhelp(void)
- {
- fprintf(stderr, "Usage: %s [options] image\n"
- "Create an ext2 filesystem image from directories/files\n\n"
- - " -x image Use this image as a starting point\n"
- - " -d directory Add this directory as source\n"
- - " -f file Add nodes (e.g. devices) from this spec file\n"
- - " -b blocks Size in blocks\n"
- - " -i inodes Number of inodes\n"
- - " -r reserved Number of reserved blocks\n"
- - " -g path Generate a block map file for this path\n"
- - " -e value Fill unallocated blocks with value\n"
- - " -z Make files with holes\n"
- - " -v Print resulting filesystem structure\n"
- - " -h Show this help\n\n"
- - "Example of spec file:\n"
- - "drwx /dev\n"
- - "crw- 10,190 /dev/lcd\n"
- - "brw- 1,0 /dev/ram0\n\n"
- - "Report bugs to xavier.bestel@free.fr\n", argv0);
- + " -x image Use this image as a starting point\n"
- + " -d directory Add this directory as source\n"
- + " -b blocks Size in blocks\n"
- + " -i inodes Number of inodes\n"
- + " -r reserved Number of reserved blocks\n"
- + " -g path Generate a block map file for this path\n"
- + " -e value Fill unallocated blocks with value\n"
- + " -z Make files with holes\n"
- + " -D,-f Use the named FILE as a device table file\n"
- + " -q Squash permissions and owners making all files be owned by root\n"
- + " -U Squash owners making all files be owned by root\n"
- + " -P Squash permissions on all files\n"
- + " -v Print resulting filesystem structure\n"
- + " -h Show this help\n\n"
- + "Report bugs to genext2fs-devel@lists.sourceforge.net\n", app_name);
- }
-
- #define MAX_DOPT 128
- @@ -1507,6 +2141,8 @@
- int nbblocks = -1;
- int nbinodes = -1;
- int nbresrvd = -1;
- + int tmp_nbblocks = -1;
- + int tmp_nbinodes = -1;
- char * fsout = "-";
- char * fsin = 0;
- char * dopt[MAX_DOPT];
- @@ -1516,19 +2152,17 @@
- int verbose = 0;
- int holes = 0;
- int emptyval = 0;
- + int squash_uids = 0;
- + int squash_perms = 0;
- uint16 endian = 1;
- int bigendian = !*(char*)&endian;
- filesystem *fs;
- int i;
- int c;
- + struct stats stats;
-
- - argv0 = argv[0];
- - if(argc <= 1)
- - {
- - showhelp();
- - exit(1);
- - }
- - while((c = getopt(argc, argv, "x:f:d:b:i:r:g:e:zvh")) != EOF)
- + app_name = argv[0];
- + while((c = getopt(argc, argv, "x:d:b:i:r:g:e:zvhD:f:qUP")) != EOF)
- switch(c)
- {
- case 'x':
- @@ -1536,6 +2170,7 @@
- break;
- case 'd':
- case 'f':
- + case 'D':
- dopt[didx++] = optarg;
- break;
- case 'b':
- @@ -1556,6 +2191,16 @@
- case 'z':
- holes = 1;
- break;
- + case 'q':
- + squash_uids = 1;
- + squash_perms = 1;
- + break;
- + case 'U':
- + squash_uids = 1;
- + break;
- + case 'P':
- + squash_perms = 1;
- + break;
- case 'v':
- verbose = 1;
- break;
- @@ -1565,17 +2210,16 @@
- default:
- exit(1);
- }
- +
- if(optind < (argc - 1))
- - errexit("too many arguments");
- + error_msg_and_die("too many arguments");
- if(optind == (argc - 1))
- fsout = argv[optind];
- if(fsin)
- {
- if(strcmp(fsin, "-"))
- {
- - FILE * fh = fopen(fsin, "r");
- - if(!fh)
- - pexit(fsin);
- + FILE * fh = xfopen(fsin, "r");
- fs = load_fs(fh, bigendian);
- fclose(fh);
- }
- @@ -1584,12 +2228,55 @@
- }
- else
- {
- + stats.ninodes = 0;
- + stats.nblocks = 0;
- + for(i = 0; i < didx; i++)
- + {
- + struct stat st;
- + FILE *fh;
- + char *pdir;
- + stat(dopt[i], &st);
- + switch(st.st_mode & S_IFMT)
- + {
- + case S_IFREG:
- + fh = xfopen(dopt[i], "r");
- + add2fs_from_file(fs, EXT2_ROOT_INO, fh, squash_uids, squash_perms, &stats);
- + fclose(fh);
- + break;
- + case S_IFDIR:
- + if(!(pdir = getcwd(0, GETCWD_SIZE)))
- + perror_msg_and_die(dopt[i]);
- + if(chdir(dopt[i]) < 0)
- + perror_msg_and_die(dopt[i]);
- + add2fs_from_dir(fs, EXT2_ROOT_INO, squash_uids, squash_perms, &stats);
- + if(chdir(pdir) < 0)
- + perror_msg_and_die(pdir);
- + free(pdir);
- + break;
- + default:
- + error_msg_and_die("%s in neither a file nor a directory", dopt[i]);
- + }
- + }
- +
- + tmp_nbinodes = stats.ninodes + EXT2_FIRST_INO + 1;
- + tmp_nbblocks = stats.nblocks; // FIXME: should add space taken by inodes too
- +
- + if(tmp_nbblocks > nbblocks)
- + {
- + printf("number of blocks too low, increasing to %d\n",tmp_nbblocks);
- + nbblocks = tmp_nbblocks;
- + }
- + if(tmp_nbinodes > nbinodes)
- + {
- + printf("number of inodes too low, increasing to %d\n",tmp_nbinodes);
- + nbinodes = tmp_nbinodes;
- + }
- if(nbblocks == -1)
- - errexit("filesystem size unspecified");
- + error_msg_and_die("filesystem size unspecified");
- if(nbinodes == -1)
- nbinodes = nbblocks * BLOCKSIZE / rndup(BYTES_PER_INODE, BLOCKSIZE);
- if(nbresrvd == -1)
- - nbresrvd = nbblocks * RESERVED_INODES;
- + nbresrvd = nbblocks * RESERVED_BLOCKS;
- fs = init_fs(nbblocks, nbinodes, nbresrvd, holes);
- }
- for(i = 0; i < didx; i++)
- @@ -1601,28 +2288,27 @@
- switch(st.st_mode & S_IFMT)
- {
- case S_IFREG:
- - if(!(fh = fopen(dopt[i], "r")))
- - pexit(dopt[i]);
- - add2fs_from_file(fs, EXT2_ROOT_INO, fh);
- + fh = xfopen(dopt[i], "r");
- + add2fs_from_file(fs, EXT2_ROOT_INO, fh, squash_uids, squash_perms, NULL);
- fclose(fh);
- break;
- case S_IFDIR:
- if(!(pdir = getcwd(0, GETCWD_SIZE)))
- - pexit(dopt[i]);
- + perror_msg_and_die(dopt[i]);
- if(chdir(dopt[i]) < 0)
- - pexit(dopt[i]);
- - add2fs_from_dir(fs, EXT2_ROOT_INO);
- + perror_msg_and_die(dopt[i]);
- + add2fs_from_dir(fs, EXT2_ROOT_INO, squash_uids, squash_perms, NULL);
- if(chdir(pdir) < 0)
- - pexit(pdir);
- + perror_msg_and_die(pdir);
- free(pdir);
- break;
- default:
- - errexit("%s in neither a file nor a directory", dopt[i]);
- + error_msg_and_die("%s in neither a file nor a directory", dopt[i]);
- }
- }
- if(emptyval)
- for(i = 1; i < fs->sb.s_blocks_count; i++)
- - if(!allocated(fs->bbm, i))
- + if(!allocated(GRP_GET_BLOCK_BITMAP(fs,i),GRP_BBM_OFFSET(fs,i)))
- memset(get_blk(fs, i), emptyval, BLOCKSIZE);
- if(verbose)
- print_fs(fs);
- @@ -1633,25 +2319,23 @@
- char *p;
- FILE *fh;
- if(!(nod = find_path(fs, EXT2_ROOT_INO, gopt[i])))
- - errexit("path %s not found in filesystem", gopt[i]);
- + error_msg_and_die("path %s not found in filesystem", gopt[i]);
- while((p = strchr(gopt[i], '/')))
- *p = '_';
- snprintf(fname, MAX_FILENAME-1, "%s.blk", gopt[i]);
- - if(!(fh = fopen(fname, "w")))
- - pexit(fname);
- + fh = xfopen(fname, "w");
- fprintf(fh, "%d:", get_nod(fs, nod)->i_size);
- flist_blocks(fs, nod, fh);
- fclose(fh);
- }
- if(strcmp(fsout, "-"))
- {
- - FILE * fh = fopen(fsout, "w");
- - if(!fh)
- - pexit(fsout);
- + FILE * fh = xfopen(fsout, "w");
- dump_fs(fs, fh, bigendian);
- fclose(fh);
- }
- else
- dump_fs(fs, stdout, bigendian);
- + free_fs(fs);
- return 0;
- }
- diff --exclude CVS -urN genext2fs-1.3.orig/install-sh genext2fs/install-sh
- --- genext2fs-1.3.orig/install-sh 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/install-sh 2004-12-27 13:03:47.000000000 -0700
- @@ -0,0 +1,325 @@
- +#!/bin/sh
- +# install - install a program, script, or datafile
- +
- +scriptversion=2004-04-01.17
- +
- +# This originates from X11R5 (mit/util/scripts/install.sh), which was
- +# later released in X11R6 (xc/config/util/install.sh) with the
- +# following copyright and license.
- +#
- +# Copyright (C) 1994 X Consortium
- +#
- +# Permission is hereby granted, free of charge, to any person obtaining a copy
- +# of this software and associated documentation files (the "Software"), to
- +# deal in the Software without restriction, including without limitation the
- +# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
- +# sell copies of the Software, and to permit persons to whom the Software is
- +# furnished to do so, subject to the following conditions:
- +#
- +# The above copyright notice and this permission notice shall be included in
- +# all copies or substantial portions of the Software.
- +#
- +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- +# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
- +# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
- +# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- +#
- +# Except as contained in this notice, the name of the X Consortium shall not
- +# be used in advertising or otherwise to promote the sale, use or other deal-
- +# ings in this Software without prior written authorization from the X Consor-
- +# tium.
- +#
- +#
- +# FSF changes to this file are in the public domain.
- +#
- +# Calling this script install-sh is preferred over install.sh, to prevent
- +# `make' implicit rules from creating a file called install from it
- +# when there is no Makefile.
- +#
- +# This script is compatible with the BSD install script, but was written
- +# from scratch. It can only install one file at a time, a restriction
- +# shared with many OS's install programs.
- +
- +# set DOITPROG to echo to test this script
- +
- +# Don't use :- since 4.3BSD and earlier shells don't like it.
- +doit="${DOITPROG-}"
- +
- +# put in absolute paths if you don't have them in your path; or use env. vars.
- +
- +mvprog="${MVPROG-mv}"
- +cpprog="${CPPROG-cp}"
- +chmodprog="${CHMODPROG-chmod}"
- +chownprog="${CHOWNPROG-chown}"
- +chgrpprog="${CHGRPPROG-chgrp}"
- +stripprog="${STRIPPROG-strip}"
- +rmprog="${RMPROG-rm}"
- +mkdirprog="${MKDIRPROG-mkdir}"
- +
- +transformbasename=
- +transform_arg=
- +instcmd="$mvprog"
- +chmodcmd="$chmodprog 0755"
- +chowncmd=
- +chgrpcmd=
- +stripcmd=
- +rmcmd="$rmprog -f"
- +mvcmd="$mvprog"
- +src=
- +dst=
- +dir_arg=
- +
- +usage="Usage: $0 [OPTION]... SRCFILE DSTFILE
- + or: $0 [OPTION]... SRCFILES... DIRECTORY
- + or: $0 -d DIRECTORIES...
- +
- +In the first form, install SRCFILE to DSTFILE, removing SRCFILE by default.
- +In the second, create the directory path DIR.
- +
- +Options:
- +-b=TRANSFORMBASENAME
- +-c copy source (using $cpprog) instead of moving (using $mvprog).
- +-d create directories instead of installing files.
- +-g GROUP $chgrp installed files to GROUP.
- +-m MODE $chmod installed files to MODE.
- +-o USER $chown installed files to USER.
- +-s strip installed files (using $stripprog).
- +-t=TRANSFORM
- +--help display this help and exit.
- +--version display version info and exit.
- +
- +Environment variables override the default commands:
- + CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG
- +"
- +
- +while test -n "$1"; do
- + case $1 in
- + -b=*) transformbasename=`echo $1 | sed 's/-b=//'`
- + shift
- + continue;;
- +
- + -c) instcmd=$cpprog
- + shift
- + continue;;
- +
- + -d) dir_arg=true
- + shift
- + continue;;
- +
- + -g) chgrpcmd="$chgrpprog $2"
- + shift
- + shift
- + continue;;
- +
- + --help) echo "$usage"; exit 0;;
- +
- + -m) chmodcmd="$chmodprog $2"
- + shift
- + shift
- + continue;;
- +
- + -o) chowncmd="$chownprog $2"
- + shift
- + shift
- + continue;;
- +
- + -s) stripcmd=$stripprog
- + shift
- + continue;;
- +
- + -t=*) transformarg=`echo $1 | sed 's/-t=//'`
- + shift
- + continue;;
- +
- + --version) echo "$0 $scriptversion"; exit 0;;
- +
- + *) # When -d is used, all remaining arguments are directories to create.
- + test -n "$dir_arg" && break
- + # Otherwise, the last argument is the destination. Remove it from $@.
- + for arg
- + do
- + if test -n "$dstarg"; then
- + # $@ is not empty: it contains at least $arg.
- + set fnord "$@" "$dstarg"
- + shift # fnord
- + fi
- + shift # arg
- + dstarg=$arg
- + done
- + break;;
- + esac
- +done
- +
- +if test -z "$1"; then
- + if test -z "$dir_arg"; then
- + echo "$0: no input file specified." >&2
- + exit 1
- + fi
- + # It's OK to call `install-sh -d' without argument.
- + # This can happen when creating conditional directories.
- + exit 0
- +fi
- +
- +for src
- +do
- + # Protect names starting with `-'.
- + case $src in
- + -*) src=./$src ;;
- + esac
- +
- + if test -n "$dir_arg"; then
- + dst=$src
- + src=
- +
- + if test -d "$dst"; then
- + instcmd=:
- + chmodcmd=
- + else
- + instcmd=$mkdirprog
- + fi
- + else
- + # Waiting for this to be detected by the "$instcmd $src $dsttmp" command
- + # might cause directories to be created, which would be especially bad
- + # if $src (and thus $dsttmp) contains '*'.
- + if test ! -f "$src" && test ! -d "$src"; then
- + echo "$0: $src does not exist." >&2
- + exit 1
- + fi
- +
- + if test -z "$dstarg"; then
- + echo "$0: no destination specified." >&2
- + exit 1
- + fi
- +
- + dst=$dstarg
- + # Protect names starting with `-'.
- + case $dst in
- + -*) dst=./$dst ;;
- + esac
- +
- + # If destination is a directory, append the input filename; won't work
- + # if double slashes aren't ignored.
- + if test -d "$dst"; then
- + dst=$dst/`basename "$src"`
- + fi
- + fi
- +
- + # This sed command emulates the dirname command.
- + dstdir=`echo "$dst" | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
- +
- + # Make sure that the destination directory exists.
- +
- + # Skip lots of stat calls in the usual case.
- + if test ! -d "$dstdir"; then
- + defaultIFS='
- + '
- + IFS="${IFS-$defaultIFS}"
- +
- + oIFS=$IFS
- + # Some sh's can't handle IFS=/ for some reason.
- + IFS='%'
- + set - `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'`
- + IFS=$oIFS
- +
- + pathcomp=
- +
- + while test $# -ne 0 ; do
- + pathcomp=$pathcomp$1
- + shift
- + if test ! -d "$pathcomp"; then
- + $mkdirprog "$pathcomp" || lasterr=$?
- + # mkdir can fail with a `File exist' error in case several
- + # install-sh are creating the directory concurrently. This
- + # is OK.
- + test ! -d "$pathcomp" && { (exit ${lasterr-1}); exit; }
- + fi
- + pathcomp=$pathcomp/
- + done
- + fi
- +
- + if test -n "$dir_arg"; then
- + $doit $instcmd "$dst" \
- + && { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \
- + && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \
- + && { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \
- + && { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; }
- +
- + else
- + # If we're going to rename the final executable, determine the name now.
- + if test -z "$transformarg"; then
- + dstfile=`basename "$dst"`
- + else
- + dstfile=`basename "$dst" $transformbasename \
- + | sed $transformarg`$transformbasename
- + fi
- +
- + # don't allow the sed command to completely eliminate the filename.
- + test -z "$dstfile" && dstfile=`basename "$dst"`
- +
- + # Make a couple of temp file names in the proper directory.
- + dsttmp=$dstdir/_inst.$$_
- + rmtmp=$dstdir/_rm.$$_
- +
- + # Trap to clean up those temp files at exit.
- + trap 'status=$?; rm -f "$dsttmp" "$rmtmp" && exit $status' 0
- + trap '(exit $?); exit' 1 2 13 15
- +
- + # Move or copy the file name to the temp name
- + $doit $instcmd "$src" "$dsttmp" &&
- +
- + # and set any options; do chmod last to preserve setuid bits.
- + #
- + # If any of these fail, we abort the whole thing. If we want to
- + # ignore errors from any of these, just make sure not to ignore
- + # errors from the above "$doit $instcmd $src $dsttmp" command.
- + #
- + { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \
- + && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \
- + && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \
- + && { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } &&
- +
- + # Now rename the file to the real destination.
- + { $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \
- + || {
- + # The rename failed, perhaps because mv can't rename something else
- + # to itself, or perhaps because mv is so ancient that it does not
- + # support -f.
- +
- + # Now remove or move aside any old file at destination location.
- + # We try this two ways since rm can't unlink itself on some
- + # systems and the destination file might be busy for other
- + # reasons. In this case, the final cleanup might fail but the new
- + # file should still install successfully.
- + {
- + if test -f "$dstdir/$dstfile"; then
- + $doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \
- + || $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \
- + || {
- + echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2
- + (exit 1); exit
- + }
- + else
- + :
- + fi
- + } &&
- +
- + # Now rename the file to the real destination.
- + $doit $mvcmd "$dsttmp" "$dstdir/$dstfile"
- + }
- + }
- + fi || { (exit 1); exit; }
- +done
- +
- +# The final little trick to "correctly" pass the exit status to the exit trap.
- +{
- + (exit 0); exit
- +}
- +
- +# Local variables:
- +# eval: (add-hook 'write-file-hooks 'time-stamp)
- +# time-stamp-start: "scriptversion="
- +# time-stamp-format: "%:y-%02m-%02d.%02H"
- +# time-stamp-end: "$"
- +# End:
- diff --exclude CVS -urN genext2fs-1.3.orig/missing genext2fs/missing
- --- genext2fs-1.3.orig/missing 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/missing 2004-12-27 13:03:47.000000000 -0700
- @@ -0,0 +1,360 @@
- +#! /bin/sh
- +# Common stub for a few missing GNU programs while installing.
- +
- +scriptversion=2003-09-02.23
- +
- +# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003
- +# Free Software Foundation, Inc.
- +# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
- +
- +# 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 to the GNU General Public License, if you
- +# distribute this file as part of a program that contains a
- +# configuration script generated by Autoconf, you may include it under
- +# the same distribution terms that you use for the rest of that program.
- +
- +if test $# -eq 0; then
- + echo 1>&2 "Try \`$0 --help' for more information"
- + exit 1
- +fi
- +
- +run=:
- +
- +# In the cases where this matters, `missing' is being run in the
- +# srcdir already.
- +if test -f configure.ac; then
- + configure_ac=configure.ac
- +else
- + configure_ac=configure.in
- +fi
- +
- +msg="missing on your system"
- +
- +case "$1" in
- +--run)
- + # Try to run requested program, and just exit if it succeeds.
- + run=
- + shift
- + "$@" && exit 0
- + # Exit code 63 means version mismatch. This often happens
- + # when the user try to use an ancient version of a tool on
- + # a file that requires a minimum version. In this case we
- + # we should proceed has if the program had been absent, or
- + # if --run hadn't been passed.
- + if test $? = 63; then
- + run=:
- + msg="probably too old"
- + fi
- + ;;
- +esac
- +
- +# If it does not exist, or fails to run (possibly an outdated version),
- +# try to emulate it.
- +case "$1" in
- +
- + -h|--h|--he|--hel|--help)
- + echo "\
- +$0 [OPTION]... PROGRAM [ARGUMENT]...
- +
- +Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
- +error status if there is no known handling for PROGRAM.
- +
- +Options:
- + -h, --help display this help and exit
- + -v, --version output version information and exit
- + --run try to run the given command, and emulate it if it fails
- +
- +Supported PROGRAM values:
- + aclocal touch file \`aclocal.m4'
- + autoconf touch file \`configure'
- + autoheader touch file \`config.h.in'
- + automake touch all \`Makefile.in' files
- + bison create \`y.tab.[ch]', if possible, from existing .[ch]
- + flex create \`lex.yy.c', if possible, from existing .c
- + help2man touch the output file
- + lex create \`lex.yy.c', if possible, from existing .c
- + makeinfo touch the output file
- + tar try tar, gnutar, gtar, then tar without non-portable flags
- + yacc create \`y.tab.[ch]', if possible, from existing .[ch]
- +
- +Send bug reports to <bug-automake@gnu.org>."
- + ;;
- +
- + -v|--v|--ve|--ver|--vers|--versi|--versio|--version)
- + echo "missing $scriptversion (GNU Automake)"
- + ;;
- +
- + -*)
- + echo 1>&2 "$0: Unknown \`$1' option"
- + echo 1>&2 "Try \`$0 --help' for more information"
- + exit 1
- + ;;
- +
- + aclocal*)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified \`acinclude.m4' or \`${configure_ac}'. You might want
- + to install the \`Automake' and \`Perl' packages. Grab them from
- + any GNU archive site."
- + touch aclocal.m4
- + ;;
- +
- + autoconf)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified \`${configure_ac}'. You might want to install the
- + \`Autoconf' and \`GNU m4' packages. Grab them from any GNU
- + archive site."
- + touch configure
- + ;;
- +
- + autoheader)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified \`acconfig.h' or \`${configure_ac}'. You might want
- + to install the \`Autoconf' and \`GNU m4' packages. Grab them
- + from any GNU archive site."
- + files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
- + test -z "$files" && files="config.h"
- + touch_files=
- + for f in $files; do
- + case "$f" in
- + *:*) touch_files="$touch_files "`echo "$f" |
- + sed -e 's/^[^:]*://' -e 's/:.*//'`;;
- + *) touch_files="$touch_files $f.in";;
- + esac
- + done
- + touch $touch_files
- + ;;
- +
- + automake*)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
- + You might want to install the \`Automake' and \`Perl' packages.
- + Grab them from any GNU archive site."
- + find . -type f -name Makefile.am -print |
- + sed 's/\.am$/.in/' |
- + while read f; do touch "$f"; done
- + ;;
- +
- + autom4te)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is needed, but is $msg.
- + You might have modified some files without having the
- + proper tools for further handling them.
- + You can get \`$1' as part of \`Autoconf' from any GNU
- + archive site."
- +
- + file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'`
- + test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'`
- + if test -f "$file"; then
- + touch $file
- + else
- + test -z "$file" || exec >$file
- + echo "#! /bin/sh"
- + echo "# Created by GNU Automake missing as a replacement of"
- + echo "# $ $@"
- + echo "exit 0"
- + chmod +x $file
- + exit 1
- + fi
- + ;;
- +
- + bison|yacc)
- + echo 1>&2 "\
- +WARNING: \`$1' $msg. You should only need it if
- + you modified a \`.y' file. You may need the \`Bison' package
- + in order for those modifications to take effect. You can get
- + \`Bison' from any GNU archive site."
- + rm -f y.tab.c y.tab.h
- + if [ $# -ne 1 ]; then
- + eval LASTARG="\${$#}"
- + case "$LASTARG" in
- + *.y)
- + SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
- + if [ -f "$SRCFILE" ]; then
- + cp "$SRCFILE" y.tab.c
- + fi
- + SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
- + if [ -f "$SRCFILE" ]; then
- + cp "$SRCFILE" y.tab.h
- + fi
- + ;;
- + esac
- + fi
- + if [ ! -f y.tab.h ]; then
- + echo >y.tab.h
- + fi
- + if [ ! -f y.tab.c ]; then
- + echo 'main() { return 0; }' >y.tab.c
- + fi
- + ;;
- +
- + lex|flex)
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified a \`.l' file. You may need the \`Flex' package
- + in order for those modifications to take effect. You can get
- + \`Flex' from any GNU archive site."
- + rm -f lex.yy.c
- + if [ $# -ne 1 ]; then
- + eval LASTARG="\${$#}"
- + case "$LASTARG" in
- + *.l)
- + SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
- + if [ -f "$SRCFILE" ]; then
- + cp "$SRCFILE" lex.yy.c
- + fi
- + ;;
- + esac
- + fi
- + if [ ! -f lex.yy.c ]; then
- + echo 'main() { return 0; }' >lex.yy.c
- + fi
- + ;;
- +
- + help2man)
- + if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
- + # We have it, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified a dependency of a manual page. You may need the
- + \`Help2man' package in order for those modifications to take
- + effect. You can get \`Help2man' from any GNU archive site."
- +
- + file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
- + if test -z "$file"; then
- + file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'`
- + fi
- + if [ -f "$file" ]; then
- + touch $file
- + else
- + test -z "$file" || exec >$file
- + echo ".ab help2man is required to generate this page"
- + exit 1
- + fi
- + ;;
- +
- + makeinfo)
- + if test -z "$run" && (makeinfo --version) > /dev/null 2>&1; then
- + # We have makeinfo, but it failed.
- + exit 1
- + fi
- +
- + echo 1>&2 "\
- +WARNING: \`$1' is $msg. You should only need it if
- + you modified a \`.texi' or \`.texinfo' file, or any other file
- + indirectly affecting the aspect of the manual. The spurious
- + call might also be the consequence of using a buggy \`make' (AIX,
- + DU, IRIX). You might want to install the \`Texinfo' package or
- + the \`GNU make' package. Grab either from any GNU archive site."
- + file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
- + if test -z "$file"; then
- + file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
- + file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file`
- + fi
- + touch $file
- + ;;
- +
- + tar)
- + shift
- + if test -n "$run"; then
- + echo 1>&2 "ERROR: \`tar' requires --run"
- + exit 1
- + fi
- +
- + # We have already tried tar in the generic part.
- + # Look for gnutar/gtar before invocation to avoid ugly error
- + # messages.
- + if (gnutar --version > /dev/null 2>&1); then
- + gnutar "$@" && exit 0
- + fi
- + if (gtar --version > /dev/null 2>&1); then
- + gtar "$@" && exit 0
- + fi
- + firstarg="$1"
- + if shift; then
- + case "$firstarg" in
- + *o*)
- + firstarg=`echo "$firstarg" | sed s/o//`
- + tar "$firstarg" "$@" && exit 0
- + ;;
- + esac
- + case "$firstarg" in
- + *h*)
- + firstarg=`echo "$firstarg" | sed s/h//`
- + tar "$firstarg" "$@" && exit 0
- + ;;
- + esac
- + fi
- +
- + echo 1>&2 "\
- +WARNING: I can't seem to be able to run \`tar' with the given arguments.
- + You may want to install GNU tar or Free paxutils, or check the
- + command line arguments."
- + exit 1
- + ;;
- +
- + *)
- + echo 1>&2 "\
- +WARNING: \`$1' is needed, and is $msg.
- + You might have modified some files without having the
- + proper tools for further handling them. Check the \`README' file,
- + it often tells you about the needed prerequisites for installing
- + this package. You may also peek at any GNU archive site, in case
- + some other package would contain this missing \`$1' program."
- + exit 1
- + ;;
- +esac
- +
- +exit 0
- +
- +# Local variables:
- +# eval: (add-hook 'write-file-hooks 'time-stamp)
- +# time-stamp-start: "scriptversion="
- +# time-stamp-format: "%:y-%02m-%02d.%02H"
- +# time-stamp-end: "$"
- +# End:
- diff --exclude CVS -urN genext2fs-1.3.orig/test-mount.sh genext2fs/test-mount.sh
- --- genext2fs-1.3.orig/test-mount.sh 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/test-mount.sh 2004-10-24 02:43:50.000000000 -0600
- @@ -0,0 +1,96 @@
- +#!/bin/sh
- +set -e
- +
- +cleanup () {
- + set +e
- + umount mnt 2>/dev/null
- + rm -rf mnt ext2.img lsout fout test 2>/dev/null
- +}
- +
- +# dtest - Uses the -d directory option of genext2fs
- +# Creates an image with a file of given size and verifies it
- +# Usage: dtest file-size number-of-blocks
- +dtest () {
- + size=$1; blocks=$2;fname=$size
- + echo "Testing with file of size $size "
- + mkdir -p test
- + cd test
- + dd if=/dev/zero of=file.$1 bs=1 count=$size
- + cd ..
- + ./genext2fs -b $blocks -d test ext2.img
- + md5=`md5sum ext2.img | cut -f1 -d " "`
- + if ! /sbin/e2fsck -fn ext2.img ; then
- + echo "fsck failed"
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + mkdir -p mnt
- + if ! mount -t ext2 -o loop ext2.img mnt; then
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + if (! [ -f mnt/file.$fname ]) || \
- + [ $fname != "`ls -al mnt | grep file.$fname |awk '{print $5}'`" ] ; then
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + echo PASSED "(md5 checksum for the image: $md5)"
- + cleanup
- +}
- +
- +# ftest - Uses the -f spec-file option of genext2fs
- +# Creates an image with the devices mentioned in the given spec
- +# file and verifies it
- +# Usage: ftest spec-file number-of-blocks
- +ftest () {
- + fname=$1; blocks=$2;
- + echo "Testing with devices file $fname"
- + ./genext2fs -b $blocks -f $fname ext2.img
- + md5=`md5sum ext2.img | cut -f 1 -d " "`
- + if ! /sbin/e2fsck -fn ext2.img ; then
- + echo "fsck failed"
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + mkdir -p mnt
- + if ! mount -t ext2 -o loop ext2.img mnt; then
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + if ! [ -d mnt/dev ] ; then
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + cat dev.txt | grep ^[bc] | \
- + awk '{print $1substr($1,2)substr($1,2),$2,$3}'| \
- + sort -d -k3.6 > fout
- + ls -al mnt/dev | grep ^[bc] | \
- + awk '{ print $1,$5$6,"/dev/"$10}' | \
- + sort -d -k3.6 > lsout
- + if ! diff fout lsout ; then
- + echo FAILED
- + cleanup
- + exit 1
- + fi
- + echo PASSED "(md5 checksum for the image: $md5)"
- + cleanup
- +}
- +
- +dtest 0 4096
- +dtest 0 8193
- +dtest 0 8194
- +dtest 1 4096
- +dtest 12288 4096
- +dtest 274432 4096
- +dtest 8388608 9000
- +dtest 16777216 20000
- +
- +ftest dev.txt 4096
- +
- +exit 0
- diff --exclude CVS -urN genext2fs-1.3.orig/test.sh genext2fs/test.sh
- --- genext2fs-1.3.orig/test.sh 1969-12-31 17:00:00.000000000 -0700
- +++ genext2fs/test.sh 2004-10-24 02:43:50.000000000 -0600
- @@ -0,0 +1,53 @@
- +#!/bin/sh
- +set -e
- +
- +# dtest - Uses the -d directory option of genext2fs
- +# Creates an image with a file of given size and verifies it
- +# Usage: dtest file-size number-of-blocks correct-checksum
- +dtest () {
- + size=$1; blocks=$2; checksum=$3
- + echo "Testing with file of size $size "
- + mkdir -p test
- + cd test
- + dd if=/dev/zero of=file.$1 bs=1 count=$size
- + cd ..
- + ./genext2fs -b $blocks -d test ext2.img
- + md5=`md5sum ext2.img | cut -d" " -f1`
- + rm -rf ext2.img test
- + if [ $md5 == $checksum ] ; then
- + echo PASSED
- + else
- + echo FAILED
- + exit 1
- + fi
- +}
- +
- +# ftest - Uses the -f spec-file option of genext2fs
- +# Creates an image with the devices mentioned in the given spec
- +# file and verifies it
- +# Usage: ftest spec-file number-of-blocks correct-checksum
- +ftest () {
- + fname=$1; blocks=$2; checksum=$3
- + echo "Testing with devices file $fname"
- + ./genext2fs -b $blocks -f $fname ext2.img
- + md5=`md5sum ext2.img | cut -d" " -f1`
- + rm -rf ext2.img
- + if [ $md5 == $checksum ] ; then
- + echo PASSED
- + else
- + echo FAILED
- + exit 1
- + fi
- +}
- +
- +dtest 0 4096 491a43ab93c2e5c186c9f1f72d88e5c5
- +dtest 0 8193 6289224f0b7f151994479ba156c43505
- +dtest 0 8194 3272c43c25e8d0c3768935861a643a65
- +dtest 1 4096 5ee24486d33af88c63080b09d8cadfb5
- +dtest 12288 4096 494498364defdc27b2770d1f9c1e3387
- +dtest 274432 4096 65c4bd8d30bf563fa5434119a12abff1
- +dtest 8388608 9000 9a49b0461ee236b7fd7c452fb6a1f2dc
- +dtest 16777216 20000 91e16429c901b68d30f783263f0611b7
- +
- +ftest dev.txt 4096 921ee9343b0759e16ad8d979d7dd16ec
- +exit 0
|