From 3a33e6baaff2cfbb162ee71585d96498375285e1 Mon Sep 17 00:00:00 2001 From: TomAwezome Date: Sat, 11 Dec 2021 06:21:22 -0500 Subject: [PATCH] Rename CosmiC to ZealC. Rename all .CC files to .ZC extension. --- build/AUTO.ISO | Bin 5011456 -> 5011456 bytes build/build_iso.sh | 4 +- src/Apps/Budget/{BgtAccts.CC => BgtAccts.ZC} | 0 src/Apps/Budget/{BgtEntry.CC => BgtEntry.ZC} | 0 src/Apps/Budget/{BgtFile.CC => BgtFile.ZC} | 0 src/Apps/Budget/{BgtMain.CC => BgtMain.ZC} | 0 src/Apps/Budget/{BgtStrs.CC => BgtStrs.ZC} | 0 .../Budget/{BgtTemplate.CC => BgtTemplate.ZC} | 0 src/Apps/Budget/{Budget.CC => Budget.ZC} | 0 src/Apps/Budget/{Install.CC => Install.ZC} | 0 src/Apps/Budget/{Load.CC => Load.ZC} | 0 src/Apps/Budget/{Run.CC => Run.ZC} | 0 src/Apps/GrModels/{BallGen.CC => BallGen.ZC} | 2 +- src/Apps/GrModels/{Load.CC => Load.ZC} | 0 src/Apps/GrModels/{ManGen.CC => ManGen.ZC} | 2 +- src/Apps/GrModels/{Models.CC => Models.ZC} | 0 src/Apps/GrModels/{Run.CC => Run.ZC} | 0 .../KeepAway/{KeepAway.CC => KeepAway.ZC} | 2 +- src/Apps/KeepAway/{Load.CC => Load.ZC} | 0 src/Apps/KeepAway/{Run.CC => Run.ZC} | 0 src/Apps/Logic/{Load.CC => Load.ZC} | 0 src/Apps/Logic/{Logic.CC => Logic.ZC} | 0 src/Apps/Logic/{Run.CC => Run.ZC} | 0 .../Examples/{childish.CC => childish.ZC} | 0 .../Psalmody/Examples/{night.CC => night.ZC} | Bin .../Examples/{prosper.CC => prosper.ZC} | Bin src/Apps/Psalmody/Help.DD | 6 +- src/Apps/Psalmody/{Install.CC => Install.ZC} | 0 src/Apps/Psalmody/{JukeBox.CC => JukeBox.ZC} | 2 +- .../Psalmody/{JukePuppet.CC => JukePuppet.ZC} | 0 src/Apps/Psalmody/{Load.CC => Load.ZC} | 0 .../Psalmody/{Psalmody.CC => Psalmody.ZC} | 0 .../{PsalmodyCtrls.CC => PsalmodyCtrls.ZC} | 0 .../{PsalmodyDraw.CC => PsalmodyDraw.ZC} | 0 .../{PsalmodyFile.CC => PsalmodyFile.ZC} | 2 +- .../{PsalmodyMain.CC => PsalmodyMain.ZC} | 0 src/Apps/Psalmody/{Run.CC => Run.ZC} | 0 src/Apps/Span/{Install.CC => Install.ZC} | 0 src/Apps/Span/{Load.CC => Load.ZC} | 0 src/Apps/Span/{Run.CC => Run.ZC} | 0 .../Span/{SpanBridge.CC => SpanBridge.ZC} | 0 .../Span/{SpanDerive.CC => SpanDerive.ZC} | 0 src/Apps/Span/{SpanMain.CC => SpanMain.ZC} | 0 src/Apps/Span/{SpanNew.CC => SpanNew.ZC} | 0 src/Apps/Strut/{Load.CC => Load.ZC} | 0 src/Apps/Strut/{Run.CC => Run.ZC} | 0 src/Apps/Strut/{Strut.CC => Strut.ZC} | 0 src/Apps/TimeClock/{Install.CC => Install.ZC} | 0 src/Apps/TimeClock/{Load.CC => Load.ZC} | 0 src/Apps/TimeClock/{TimeClk.CC => TimeClk.ZC} | 0 src/Apps/Titanium/{Load.CC => Load.ZC} | 0 src/Apps/Titanium/{Run.CC => Run.ZC} | 0 .../Titanium/{Titanium.CC => Titanium.ZC} | 0 .../ToTheFront/AIs/{Human.CC => Human.ZC} | 0 .../AIs/{SimpleAI.CC => SimpleAI.ZC} | 0 .../ToTheFront/{Install.CC => Install.ZC} | 0 src/Apps/ToTheFront/{Load.CC => Load.ZC} | 0 src/Apps/ToTheFront/{Run.CC => Run.ZC} | 0 .../ToTheFront/{TTFDraw.CC => TTFDraw.ZC} | Bin .../ToTheFront/{TTFFire.CC => TTFFire.ZC} | 0 .../{TTFGlobals.CC => TTFGlobals.ZC} | 0 .../ToTheFront/{TTFInit.CC => TTFInit.ZC} | 4 +- src/Apps/ToTheFront/{TTFLib.CC => TTFLib.ZC} | 0 .../ToTheFront/{TTFMove.CC => TTFMove.ZC} | 0 src/Apps/ToTheFront/{TTFVis.CC => TTFVis.ZC} | 0 .../{ToTheFront.CC => ToTheFront.ZC} | 0 src/Apps/Vocabulary/{Load.CC => Load.ZC} | 0 src/Apps/Vocabulary/{Run.CC => Run.ZC} | 0 .../Vocabulary/{VocabQuiz.CC => VocabQuiz.ZC} | 0 src/Apps/X-Caliber/{Load.CC => Load.ZC} | 0 src/Apps/X-Caliber/{Run.CC => Run.ZC} | 0 .../X-Caliber/{X-Caliber.CC => X-Caliber.ZC} | 0 src/Apps/X-Caliber/{XCCtrls.CC => XCCtrls.ZC} | 0 src/Compiler/{Asm.CC => Asm.ZC} | 0 src/Compiler/{AsmInit.CC => AsmInit.ZC} | 0 src/Compiler/{AsmLib.CC => AsmLib.ZC} | 0 src/Compiler/{AsmResolve.CC => AsmResolve.ZC} | 0 src/Compiler/{BackA.CC => BackA.ZC} | 0 src/Compiler/{BackB.CC => BackB.ZC} | 0 src/Compiler/{BackC.CC => BackC.ZC} | 0 src/Compiler/{BackFA.CC => BackFA.ZC} | 0 src/Compiler/{BackFB.CC => BackFB.ZC} | 0 src/Compiler/{BackLib.CC => BackLib.ZC} | 0 src/Compiler/{CExcept.CC => CExcept.ZC} | 0 src/Compiler/{CExterns.CC => CExterns.ZC} | 0 src/Compiler/{CHash.CC => CHash.ZC} | 0 src/Compiler/{CInit.CC => CInit.ZC} | 0 src/Compiler/{CMain.CC => CMain.ZC} | 4 +- src/Compiler/{CMisc.CC => CMisc.ZC} | 0 src/Compiler/{Lex.CC => Lex.ZC} | 4 +- src/Compiler/{LexLib.CC => LexLib.ZC} | 4 +- src/Compiler/{OptLib.CC => OptLib.ZC} | 0 src/Compiler/{OptPass012.CC => OptPass012.ZC} | 2 +- src/Compiler/{OptPass3.CC => OptPass3.ZC} | 0 src/Compiler/{OptPass4.CC => OptPass4.ZC} | 2 +- src/Compiler/{OptPass5.CC => OptPass5.ZC} | 0 src/Compiler/{OptPass6.CC => OptPass6.ZC} | 0 .../{OptPass789A.CC => OptPass789A.ZC} | 0 src/Compiler/{ParseExp.CC => ParseExp.ZC} | 0 src/Compiler/{ParseLib.CC => ParseLib.ZC} | 0 .../{ParseStatement.CC => ParseStatement.ZC} | 0 src/Compiler/{ParseVar.CC => ParseVar.ZC} | 0 src/Compiler/{Templates.CC => Templates.ZC} | 0 src/Compiler/{UAsm.CC => UAsm.ZC} | 0 .../{HomeKeyPlugIns.CC => HomeKeyPlugIns.ZC} | 0 .../{HomeLocalize.CC => HomeLocalize.ZC} | 0 .../AcctExample/{HomeSys.CC => HomeSys.ZC} | 0 .../{HomeWrappers.CC => HomeWrappers.ZC} | 0 .../AcctExample/{MakeHome.CC => MakeHome.ZC} | 0 src/Demo/AcctExample/{Once.CC => Once.ZC} | 6 +- src/Demo/AcctExample/PersonalMenu.DD | Bin 66513 -> 66513 bytes src/Demo/AcctExample/PersonalNotes.DD | 72 ++-- .../AcctExample/{Registry.CC => Registry.ZC} | 0 .../TOS/{MakeTOS.CC => MakeTOS.ZC} | 0 .../TOS/{TOSConfig.CC => TOSConfig.ZC} | 0 .../TOS/{TOSDistro.CC => TOSDistro.ZC} | 30 +- .../TOS/{TOSExtern.CC => TOSExtern.ZC} | 0 .../TOS/{TOSMisc.CC => TOSMisc.ZC} | 0 .../TOS/{TOSTheme.CC => TOSTheme.ZC} | Bin src/Demo/Asm/{AsmAndC1.CC => AsmAndC1.ZC} | 0 src/Demo/Asm/{AsmAndC2.CC => AsmAndC2.ZC} | 2 +- src/Demo/Asm/{AsmAndC3.CC => AsmAndC3.ZC} | 0 .../{AsmHelloWorld.CC => AsmHelloWorld.ZC} | 2 +- src/Demo/Asm/{BuzzFizz.CC => BuzzFizz.ZC} | 0 src/Demo/Asm/{DivByHand.CC => DivByHand.ZC} | 0 src/Demo/Asm/{MulByHand.CC => MulByHand.ZC} | 0 src/Demo/Asm/{PutDec.CC => PutDec.ZC} | 0 src/Demo/{Carry.CC => Carry.ZC} | 0 src/Demo/{ClassMeta.CC => ClassMeta.ZC} | 2 +- src/Demo/{CompileDemo.CC => CompileDemo.ZC} | 0 src/Demo/{DateTime.CC => DateTime.ZC} | 0 src/Demo/{DebugDemo.CC => DebugDemo.ZC} | 0 src/Demo/{Define.CC => Define.ZC} | 0 src/Demo/{Directives.CC => Directives.ZC} | 0 src/Demo/Disk/{DataBase.CC => DataBase.ZC} | 0 src/Demo/Disk/{DiskRaw.CC => DiskRaw.ZC} | 0 src/Demo/Disk/{FPrintF.CC => FPrintF.ZC} | 0 .../{SerializeTree.CC => SerializeTree.ZC} | 0 .../{UnusedSpaceRep.CC => UnusedSpaceRep.ZC} | 0 src/Demo/DolDoc/{CallBack.CC => CallBack.ZC} | 2 +- .../{ClickCallBack.CC => ClickCallBack.ZC} | 2 +- .../DolDoc/{CursorMove.CC => CursorMove.ZC} | 0 src/Demo/DolDoc/{Data.CC => Data.ZC} | 2 +- .../DolDoc/{DefineStr.CC => DefineStr.ZC} | 0 src/Demo/DolDoc/{FileRead.CC => FileRead.ZC} | 4 +- src/Demo/DolDoc/{Form.CC => Form.ZC} | 0 src/Demo/DolDoc/{MenuBttn.CC => MenuBttn.ZC} | 0 .../DolDoc/{MenuSprite.CC => MenuSprite.ZC} | Bin src/Demo/DolDoc/{NumBible.CC => NumBible.ZC} | 0 src/Demo/DolDoc/{TextDemo.CC => TextDemo.ZC} | 4 +- src/Demo/DolDoc/{TreeDemo.CC => TreeDemo.ZC} | 0 .../{UnusedDefine.CC => UnusedDefine.ZC} | 0 src/Demo/{Exceptions.CC => Exceptions.ZC} | 0 src/Demo/{ExtChars.CC => ExtChars.ZC} | 4 +- .../Games/{BattleLines.CC => BattleLines.ZC} | 2 +- src/Demo/Games/{BigGuns.CC => BigGuns.ZC} | Bin 6997 -> 6997 bytes .../{BlackDiamond.CC => BlackDiamond.ZC} | Bin .../Games/{BomberGolf.CC => BomberGolf.ZC} | Bin ...eFrankenstein.CC => CastleFrankenstein.ZC} | 2 +- src/Demo/Games/{CharDemo.CC => CharDemo.ZC} | 4 +- src/Demo/Games/{Chess.CC => Chess.ZC} | 0 .../Games/{CircleTrace.CC => CircleTrace.ZC} | 0 src/Demo/Games/{Collision.CC => Collision.ZC} | Bin 4404 -> 4404 bytes src/Demo/Games/{Digits.CC => Digits.ZC} | 2 +- src/Demo/Games/{DunGen.CC => DunGen.ZC} | 2 +- .../{ElephantWalk.CC => ElephantWalk.ZC} | Bin src/Demo/Games/{FlapBat.CC => FlapBat.ZC} | Bin src/Demo/Games/{FlatTops.CC => FlatTops.ZC} | 0 src/Demo/Games/{Halogen.CC => Halogen.ZC} | 0 .../Games/{MassSpring.CC => MassSpring.ZC} | 0 src/Demo/Games/{Maze.CC => Maze.ZC} | 0 src/Demo/Games/{RainDrops.CC => RainDrops.ZC} | 0 src/Demo/Games/{RawHide.CC => RawHide.ZC} | 2 +- src/Demo/Games/{Rocket.CC => Rocket.ZC} | Bin .../{RocketScience.CC => RocketScience.ZC} | Bin src/Demo/Games/{Squirt.CC => Squirt.ZC} | 0 .../Games/Stadium/{Stadium.CC => Stadium.ZC} | Bin .../Stadium/{StadiumGen.CC => StadiumGen.ZC} | 0 src/Demo/Games/{Talons.CC => Talons.ZC} | 2 +- src/Demo/Games/{TheDead.CC => TheDead.ZC} | Bin src/Demo/Games/{TicTacToe.CC => TicTacToe.ZC} | 0 .../{TreeCheckers.CC => TreeCheckers.ZC} | 0 src/Demo/Games/{Varoom.CC => Varoom.ZC} | 0 src/Demo/Games/{Wenceslas.CC => Wenceslas.ZC} | 0 src/Demo/Games/{Whap.CC => Whap.ZC} | 0 src/Demo/Games/{Zing.CC => Zing.ZC} | Bin src/Demo/Games/{ZoneOut.CC => ZoneOut.ZC} | Bin src/Demo/{GlobalVars.CC => GlobalVars.ZC} | 0 .../Graphics/{32BitColor.CC => 32BitColor.ZC} | 0 .../Graphics/{32BitPaint.CC => 32BitPaint.ZC} | 0 src/Demo/Graphics/{3DPoly.CC => 3DPoly.ZC} | 0 src/Demo/Graphics/{BSpline.CC => BSpline.ZC} | 0 src/Demo/Graphics/{Blot.CC => Blot.ZC} | 0 src/Demo/Graphics/{Bounce.CC => Bounce.ZC} | 2 +- src/Demo/Graphics/{Box.CC => Box.ZC} | 0 .../Graphics/{Cartesian.CC => Cartesian.ZC} | 2 +- .../{CharAnimation.CC => CharAnimation.ZC} | 4 +- src/Demo/Graphics/{Clock.CC => Clock.ZC} | 0 .../Graphics/{Collision.CC => Collision.ZC} | Bin .../{CommonAncestor.CC => CommonAncestor.ZC} | 2 +- src/Demo/Graphics/{Doodle.CC => Doodle.ZC} | 0 .../Graphics/{EdSprite.CC => EdSprite.ZC} | Bin .../Graphics/{Elephant.CC => Elephant.ZC} | Bin src/Demo/Graphics/{Extents.CC => Extents.ZC} | Bin src/Demo/Graphics/{FontEd.CC => FontEd.ZC} | 6 +- src/Demo/Graphics/{GrDir.CC => GrDir.ZC} | Bin 8599 -> 8599 bytes src/Demo/Graphics/{Grid.CC => Grid.ZC} | 0 src/Demo/Graphics/{Hanoi.CC => Hanoi.ZC} | 0 src/Demo/Graphics/{Lattice.CC => Lattice.ZC} | 0 src/Demo/Graphics/{Life.CC => Life.ZC} | 0 .../Graphics/{LightTable.CC => LightTable.ZC} | 0 src/Demo/Graphics/{Lines.CC => Lines.ZC} | 0 .../{LowPassFilter.CC => LowPassFilter.ZC} | 0 .../{MathAudioDemo.CC => MathAudioDemo.ZC} | 0 .../Graphics/{MouseDemo.CC => MouseDemo.ZC} | 0 .../Graphics/{NetOfDots.CC => NetOfDots.ZC} | 0 src/Demo/Graphics/{Palette.CC => Palette.ZC} | 0 src/Demo/Graphics/{PanText.CC => PanText.ZC} | 0 src/Demo/Graphics/{Pick.CC => Pick.ZC} | Bin src/Demo/Graphics/{Pick3D.CC => Pick3D.ZC} | Bin .../Graphics/{PoleZeros.CC => PoleZeros.ZC} | 0 .../{PredatorPrey.CC => PredatorPrey.ZC} | 0 .../Graphics/{RotateTank.CC => RotateTank.ZC} | Bin .../{ScreenCapture.CC => ScreenCapture.ZC} | 2 +- .../Graphics/{ScrollBars.CC => ScrollBars.ZC} | Bin src/Demo/Graphics/{Shading.CC => Shading.ZC} | 2 +- src/Demo/Graphics/{Shadow.CC => Shadow.ZC} | Bin src/Demo/Graphics/{Slider.CC => Slider.ZC} | 0 .../Graphics/{Speedline.CC => Speedline.ZC} | 0 .../Graphics/{SpritePlot.CC => SpritePlot.ZC} | Bin .../{SpritePlot3D.CC => SpritePlot3D.ZC} | Bin .../Graphics/{SpritePut.CC => SpritePut.ZC} | Bin 24899 -> 24899 bytes .../{SpritePutExt.CC => SpritePutExt.ZC} | 4 +- .../Graphics/{SpriteRaw.CC => SpriteRaw.ZC} | 0 .../Graphics/{SpriteText.CC => SpriteText.ZC} | Bin src/Demo/Graphics/{SunMoon.CC => SunMoon.ZC} | 0 .../Graphics/{Symmetry.CC => Symmetry.ZC} | 0 .../Graphics/{Transform.CC => Transform.ZC} | Bin .../{WallPaperCtrl.CC => WallPaperCtrl.ZC} | 4 +- .../{WallPaperFish.CC => WallPaperFish.ZC} | Bin .../{WallPaperStars.CC => WallPaperStars.ZC} | 0 src/Demo/Graphics/{WinZBuf.CC => WinZBuf.ZC} | 0 src/Demo/InFile/{InPopUp.CC => InPopUp.ZC} | 0 src/Demo/InFile/{InSetIP.CC => InSetIP.ZC} | 0 src/Demo/{KeyBitMap.CC => KeyBitMap.ZC} | Bin src/Demo/{LastClass.CC => LastClass.ZC} | 2 +- src/Demo/Lectures/64BitAsmQuiz.DD | 2 +- .../Lectures/{AndNotMod.CC => AndNotMod.ZC} | 0 .../Lectures/{FixedPoint.CC => FixedPoint.ZC} | 4 +- ...PointAdvanced.CC => FixedPointAdvanced.ZC} | 2 +- .../{InterruptDemo.CC => InterruptDemo.ZC} | 0 .../{MiniCompiler.CC => MiniCompiler.ZC} | 8 +- .../Lectures/{MiniGrLib.CC => MiniGrLib.ZC} | 0 src/Demo/Lectures/{NegDisp.CC => NegDisp.ZC} | 0 .../{Optimization.CC => Optimization.ZC} | 0 .../{PCIInterrupts.CC => PCIInterrupts.ZC} | 0 src/Demo/Lectures/{Ring3.CC => Ring3.ZC} | 0 src/Demo/{MagicPairs.CC => MagicPairs.ZC} | 0 src/Demo/{MemDemo.CC => MemDemo.ZC} | 0 src/Demo/{MessageLoop.CC => MessageLoop.ZC} | 0 .../{Interrupts.CC => Interrupts.ZC} | 0 .../MultiCore/{LoadTest.CC => LoadTest.ZC} | 2 +- src/Demo/MultiCore/{Lock.CC => Lock.ZC} | 0 src/Demo/MultiCore/{MPAdd.CC => MPAdd.ZC} | 0 src/Demo/MultiCore/{MPPrint.CC => MPPrint.ZC} | 0 src/Demo/MultiCore/{MPRadix.CC => MPRadix.ZC} | 0 .../{Palindrome.CC => Palindrome.ZC} | 0 src/Demo/MultiCore/{Primes.CC => Primes.ZC} | 0 src/Demo/{NullCase.CC => NullCase.ZC} | 0 src/Demo/{OnceDemo.CC => OnceDemo.ZC} | 0 src/Demo/{ParenWarn.CC => ParenWarn.ZC} | 0 .../{PhoneNumWords.CC => PhoneNumWords.ZC} | 0 src/Demo/{Print.CC => Print.ZC} | 0 src/Demo/{Progress.CC => Progress.ZC} | 0 src/Demo/{Prompt.CC => Prompt.ZC} | 0 src/Demo/{PullDownMenu.CC => PullDownMenu.ZC} | 0 src/Demo/{RadixSort.CC => RadixSort.ZC} | 0 src/Demo/{RandDemo.CC => RandDemo.ZC} | 2 +- src/Demo/{RegistryDemo.CC => RegistryDemo.ZC} | 2 +- src/Demo/RevFileDemo/{Rev.CC => Rev.ZC} | 0 src/Demo/{ScreenCodes.CC => ScreenCodes.ZC} | 4 +- .../{F64FileGen.CC => F64FileGen.ZC} | 2 +- .../{F64FileSort.CC => F64FileSort.ZC} | 4 +- .../Sound/{ASCIIOrgan.CC => ASCIIOrgan.ZC} | Bin src/Demo/Sound/{MorseCode.CC => MorseCode.ZC} | 0 src/Demo/Sound/{OhGreat.CC => OhGreat.ZC} | 0 src/Demo/Sound/{WaterFowl.CC => WaterFowl.ZC} | Bin src/Demo/{Spy.CC => Spy.ZC} | 0 src/Demo/{StackGrow.CC => StackGrow.ZC} | 0 src/Demo/{SubIntAccess.CC => SubIntAccess.ZC} | 2 +- src/Demo/{SubSwitch.CC => SubSwitch.ZC} | 0 ...{SuggestSpelling.CC => SuggestSpelling.ZC} | 0 src/Demo/Templates/{Game1.CC => Game1.ZC} | 0 src/Demo/Templates/{Lex1.CC => Lex1.ZC} | 0 .../{MultiCore1.CC => MultiCore1.ZC} | 0 src/Demo/Templates/{ODE1.CC => ODE1.ZC} | 0 .../Templates/{Registry1.CC => Registry1.ZC} | 0 src/Demo/Templates/{Util1.CC => Util1.ZC} | 0 src/Demo/Templates/{Util2.CC => Util2.ZC} | 0 src/Demo/{TimeIns.CC => TimeIns.ZC} | 0 .../{HtmlDirList.CC => HtmlDirList.ZC} | 0 .../{HtmlGen.CC => HtmlGen.ZC} | 6 +- .../ToHtmlToTXTDemo/{TXTGen.CC => TXTGen.ZC} | 0 .../ToHtmlToTXTDemo/{ToHtml.CC => ToHtml.ZC} | 2 +- .../WebLogDemo/{WebLogRep.CC => WebLogRep.ZC} | 0 .../{WebLogScramble.CC => WebLogScramble.ZC} | 0 src/Demo/{WordSearch.CC => WordSearch.ZC} | 2 +- src/Doc/Asm.DD | 2 +- src/Doc/AutoComplete.DD | 4 +- src/Doc/BlkChain.DD | 2 +- src/Doc/Boot.DD | Bin 5447 -> 5447 bytes src/Doc/ChangeLog.DD | 114 ++++--- src/Doc/CharOverview.DD | 2 +- src/Doc/CmdLineOverview.DD | 4 +- src/Doc/{Comm.CC => Comm.ZC} | 0 src/Doc/CompilerOverview.DD | 4 +- src/Doc/Credits.DD | 6 +- src/Doc/Ctrls.DD | 2 +- src/Doc/Customize.DD | 8 +- src/Doc/CutCorners.DD | 2 +- src/Doc/Define.DD | 6 +- src/Doc/DemoIndex.DD | 320 +++++++++--------- src/Doc/Directives.DD | 2 +- src/Doc/DolDocOverview.DD | 64 ++-- src/Doc/FAQ.DD | 12 +- src/Doc/FileMgr.DD | 2 +- src/Doc/Frame.DD | 2 +- src/Doc/Glossary.DD | 6 +- src/Doc/GraphicsOverview.DD | Bin 6818 -> 6818 bytes src/Doc/GuideLines.DD | 18 +- src/Doc/Hash.DD | Bin 2098 -> 2098 bytes src/Doc/HelloWorld.DD | 18 +- src/Doc/HelpIndex.DD | Bin 6838 -> 6838 bytes src/Doc/Install.DD | 2 +- src/Doc/KeyDev.DD | 2 +- src/Doc/Lex.DD | 2 +- src/Doc/MemoryOverview.DD | 10 +- src/Doc/Menus.DD | 2 +- src/Doc/Mouse.DD | 2 +- src/Doc/MultiCore.DD | 8 +- src/Doc/ODE.DD | 2 +- src/Doc/Once.DD | 14 +- src/Doc/PreProcessor.DD | 2 +- src/Doc/Print.DD | 8 +- src/Doc/RedSea.DD | 4 +- src/Doc/Sprite.DD | 4 +- src/Doc/StdOutTask.DD | 2 +- src/Doc/Strategy.DD | 2 +- src/Doc/TextBase.DD | 2 +- src/Doc/Tips.DD | 30 +- src/Doc/Transform.DD | 8 +- src/Doc/Welcome.DD | 78 ++--- src/Doc/WhyNotMore.DD | 6 +- src/Doc/Widget.DD | 2 +- src/Doc/ZealC.DD | 22 +- src/Home/{DoDistro.CC => DoDistro.ZC} | 8 +- src/Home/{HtmlGen.CC => HtmlGen.ZC} | 8 +- src/Home/{K.CC => K.ZC} | 4 +- src/Home/Net/Drivers/{E1000.CC => E1000.ZC} | 0 src/Home/Net/Drivers/{PCNet.CC => PCNet.ZC} | 2 +- src/Home/Net/Drivers/{Run.CC => Run.ZC} | 0 .../Drivers/{VirtIONet.CC => VirtIONet.ZC} | 0 src/Home/Net/{Load.CC => Load.ZC} | 0 .../Net/Programs/{Gopher.CC => Gopher.ZC} | 2 +- .../{TCPChatClient.CC => TCPChatClient.ZC} | 0 .../{TCPChatServer.CC => TCPChatServer.ZC} | 0 .../Net/Programs/{UDPChat.CC => UDPChat.ZC} | 0 src/Home/Net/Protocols/{ARP.CC => ARP.ZC} | 0 src/Home/Net/Protocols/{DHCP.CC => DHCP.ZC} | 0 src/Home/Net/Protocols/{DNS.CC => DNS.ZC} | 0 .../Protocols/{Ethernet.CC => Ethernet.ZC} | 0 src/Home/Net/Protocols/{ICMP.CC => ICMP.ZC} | 0 src/Home/Net/Protocols/{IPV4.CC => IPV4.ZC} | 0 .../Net/Protocols/{Sockets.CC => Sockets.ZC} | 0 .../Protocols/TCP/{MakeTCP.CC => MakeTCP.ZC} | 2 +- src/Home/Net/Protocols/TCP/{TCP.CC => TCP.ZC} | 0 .../TCP/{TCPHandler.CC => TCPHandler.ZC} | 0 .../Protocols/TCP/{TCPTree.CC => TCPTree.ZC} | 0 .../Protocols/UDP/{MakeUDP.CC => MakeUDP.ZC} | 2 +- src/Home/Net/Protocols/UDP/{UDP.CC => UDP.ZC} | 0 .../Protocols/UDP/{UDPTree.CC => UDPTree.ZC} | 0 src/Home/Net/{Start.CC => Start.ZC} | 0 src/Home/Net/Tests/{ARPTest.CC => ARPTest.ZC} | 0 .../Net/Tests/{DHCPTest0.CC => DHCPTest0.ZC} | 0 .../Net/Tests/{DHCPTest1.CC => DHCPTest1.ZC} | 0 .../Net/Tests/{DHCPTest2.CC => DHCPTest2.ZC} | 2 +- src/Home/Net/Tests/{DNSTest.CC => DNSTest.ZC} | 0 .../{EthernetTest.CC => EthernetTest.ZC} | 0 .../Net/Tests/{HostTest0.CC => HostTest0.ZC} | 0 .../Net/Tests/{HostTest1.CC => HostTest1.ZC} | 0 .../Net/Tests/{ICMPTest.CC => ICMPTest.ZC} | 0 .../Net/Tests/{IPV4Test.CC => IPV4Test.ZC} | 0 .../Net/Tests/{PCNetTest.CC => PCNetTest.ZC} | 0 src/Home/Net/Tests/{PCP.CC => PCP.ZC} | 0 .../{TCPEchoClient.CC => TCPEchoClient.ZC} | 0 .../{TCPEchoServer.CC => TCPEchoServer.ZC} | 0 .../Net/Tests/{TCPTest0.CC => TCPTest0.ZC} | 0 .../Net/Tests/{TCPTest1.CC => TCPTest1.ZC} | 0 .../Net/Tests/{TCPTest2.CC => TCPTest2.ZC} | 0 .../{UDPSocketTest0.CC => UDPSocketTest0.ZC} | 0 .../{UDPSocketTest1.CC => UDPSocketTest1.ZC} | 0 .../{UDPSocketTest2.CC => UDPSocketTest2.ZC} | 0 .../Net/Tests/{UDPTest0.CC => UDPTest0.ZC} | 0 .../Net/Tests/{UDPTest1.CC => UDPTest1.ZC} | 0 src/Home/Net/Utilities/{BST.CC => BST.ZC} | 0 .../Net/Utilities/JSON/{JSON.CC => JSON.ZC} | 0 src/Home/Net/Utilities/Net.HH | 4 +- .../{NetHandler.CC => NetHandler.ZC} | 0 .../Net/Utilities/{NetLog.CC => NetLog.ZC} | 0 .../Utilities/{NetQueue.CC => NetQueue.ZC} | 0 src/Home/PaletteEditor/{Load.CC => Load.ZC} | 0 .../{PaletteEdit.CC => PaletteEdit.ZC} | 2 +- .../{PaletteGod.CC => PaletteGod.ZC} | 0 .../{PaletteSelect.CC => PaletteSelect.ZC} | 4 +- .../Palettes/{Commander.CC => Commander.ZC} | 0 .../Palettes/{Green.CC => Green.ZC} | 0 .../Palettes/{Marine.CC => Marine.ZC} | 0 .../Palettes/{Slate.CC => Slate.ZC} | 0 .../Palettes/{Temple.CC => Temple.ZC} | 0 .../Palettes/{Zsnes.CC => Zsnes.ZC} | 0 src/Home/PaletteEditor/{Run.CC => Run.ZC} | 0 src/Home/{SSE.CC => SSE.ZC} | 0 src/{HomeKeyPlugIns.CC => HomeKeyPlugIns.ZC} | 0 src/{HomeLocalize.CC => HomeLocalize.ZC} | 0 src/{HomeSys.CC => HomeSys.ZC} | 2 +- src/{HomeWrappers.CC => HomeWrappers.ZC} | 0 .../BlkDev/{DiskAHCI.CC => DiskAHCI.ZC} | 0 .../BlkDev/{DiskATAId.CC => DiskATAId.ZC} | 2 +- .../BlkDev/{DiskAddDev.CC => DiskAddDev.ZC} | 0 src/Kernel/BlkDev/{DiskBlk.CC => DiskBlk.ZC} | 0 .../BlkDev/{DiskBlkDev.CC => DiskBlkDev.ZC} | 0 .../BlkDev/{DiskCDDVD.CC => DiskCDDVD.ZC} | 0 .../BlkDev/{DiskCFile.CC => DiskCFile.ZC} | 0 .../BlkDev/{DiskCache.CC => DiskCache.ZC} | 0 .../BlkDev/{DiskClus.CC => DiskClus.ZC} | 0 .../BlkDev/{DiskCopy.CC => DiskCopy.ZC} | 0 .../BlkDev/{DiskDirA.CC => DiskDirA.ZC} | 0 .../BlkDev/{DiskDirB.CC => DiskDirB.ZC} | 0 .../{DiskDirContext.CC => DiskDirContext.ZC} | 0 .../BlkDev/{DiskDrive.CC => DiskDrive.ZC} | 0 .../BlkDev/{DiskFile.CC => DiskFile.ZC} | 0 .../BlkDev/{DiskFind.CC => DiskFind.ZC} | 0 .../BlkDev/{DiskFormat.CC => DiskFormat.ZC} | 0 .../BlkDev/{DiskStrA.CC => DiskStrA.ZC} | 4 +- .../BlkDev/{DiskStrB.CC => DiskStrB.ZC} | 0 .../BlkDev/{FileSysFAT.CC => FileSysFAT.ZC} | 0 .../{FileSysRedSea.CC => FileSysRedSea.ZC} | 0 .../BlkDev/{MakeBlkDev.CC => MakeBlkDev.ZC} | 0 src/Kernel/{Display.CC => Display.ZC} | 0 src/Kernel/{EdLite.CC => EdLite.ZC} | 2 +- src/Kernel/{FontStd.CC => FontStd.ZC} | 0 src/Kernel/{FunSeg.CC => FunSeg.ZC} | 0 src/Kernel/{Job.CC => Job.ZC} | 6 +- src/Kernel/{KConfig.CC => KConfig.ZC} | 0 src/Kernel/{KDataTypes.CC => KDataTypes.ZC} | 0 src/Kernel/{KDate.CC => KDate.ZC} | 0 src/Kernel/{KDebug.CC => KDebug.ZC} | 2 +- src/Kernel/{KDefine.CC => KDefine.ZC} | 0 src/Kernel/{KExcept.CC => KExcept.ZC} | 0 src/Kernel/{KExterns.CC => KExterns.ZC} | 0 src/Kernel/{KGlobals.CC => KGlobals.ZC} | 6 +- src/Kernel/{KHashA.CC => KHashA.ZC} | 0 src/Kernel/{KHashB.CC => KHashB.ZC} | 2 +- src/Kernel/{KInterrupts.CC => KInterrupts.ZC} | 6 +- src/Kernel/{KLoad.CC => KLoad.ZC} | 4 +- src/Kernel/{KMain.CC => KMain.ZC} | 4 +- src/Kernel/{KMathA.CC => KMathA.ZC} | 0 src/Kernel/{KMathB.CC => KMathB.ZC} | 0 src/Kernel/{KMisc.CC => KMisc.ZC} | 2 +- src/Kernel/{KStart16.CC => KStart16.ZC} | 10 +- src/Kernel/{KStart32.CC => KStart32.ZC} | 2 +- src/Kernel/{KStart64.CC => KStart64.ZC} | 2 +- src/Kernel/{KTask.CC => KTask.ZC} | 8 +- src/Kernel/{KUtils.CC => KUtils.ZC} | 0 src/Kernel/Kernel.PRJ | 2 +- src/Kernel/KernelA.HH | 36 +- src/Kernel/KernelB.HH | 4 +- src/Kernel/{KeyDev.CC => KeyDev.ZC} | 0 src/Kernel/Memory/{BlkPool.CC => BlkPool.ZC} | 2 +- .../Memory/{HeapCtrl.CC => HeapCtrl.ZC} | 2 +- .../Memory/{MAllocFree.CC => MAllocFree.ZC} | 2 +- .../Memory/{MakeMemory.CC => MakeMemory.ZC} | 0 src/Kernel/Memory/{MemPag.CC => MemPag.ZC} | 0 .../Memory/{MemPhysical.CC => MemPhysical.ZC} | 0 .../Memory/{PageTables.CC => PageTables.ZC} | 0 src/Kernel/{MultiProc.CC => MultiProc.ZC} | 12 +- src/Kernel/{PCI.CC => PCI.ZC} | 0 src/Kernel/{PCIBIOS.CC => PCIBIOS.ZC} | 0 src/Kernel/{QuickSort.CC => QuickSort.ZC} | 4 +- src/Kernel/{Sched.CC => Sched.ZC} | 0 .../SerialDev/{Keyboard.CC => Keyboard.ZC} | 0 .../{MakeSerialDev.CC => MakeSerialDev.ZC} | 0 .../SerialDev/{Message.CC => Message.ZC} | 2 +- src/Kernel/SerialDev/{Mouse.CC => Mouse.ZC} | 4 +- src/Kernel/{StrA.CC => StrA.ZC} | 0 src/Kernel/{StrB.CC => StrB.ZC} | 2 +- src/Kernel/{StrPrint.CC => StrPrint.ZC} | 0 src/Kernel/{StrScan.CC => StrScan.ZC} | 0 src/{MakeHome.CC => MakeHome.ZC} | 0 .../Auto/{AutoDistro.CC => AutoDistro.ZC} | 6 +- ...{AutoFullDistro0.CC => AutoFullDistro0.ZC} | 0 ...{AutoFullDistro1.CC => AutoFullDistro1.ZC} | 0 ...{AutoFullDistro2.CC => AutoFullDistro2.ZC} | 4 +- .../Auto/{AutoInstall.CC => AutoInstall.ZC} | 10 +- src/Misc/Auto/{BootMHD2.CC => BootMHD2.ZC} | 2 +- src/Misc/Auto/{HomeSys.CC => HomeSys.ZC} | 0 src/Misc/Auto/{Once.CC => Once.ZC} | 4 +- src/Misc/{DoDistro.CC => DoDistro.ZC} | 4 +- src/Misc/{OSInstall.CC => OSInstall.ZC} | 10 +- src/Misc/{OSTestSuite.CC => OSTestSuite.ZC} | 0 src/Misc/Tour/Tour3.IN | 6 +- src/Misc/Tour/Tour4.IN | 2 +- src/Misc/Tour/Tour7.IN | 4 +- src/{Once.CC => Once.ZC} | 2 +- src/PersonalMenu.DD | Bin 65015 -> 65015 bytes src/{StartOS.CC => StartOS.ZC} | 2 +- .../{ACDictGen.CC => ACDictGen.ZC} | 0 .../AutoComplete/{ACFill.CC => ACFill.ZC} | 0 .../AutoComplete/{ACInit.CC => ACInit.ZC} | 0 .../AutoComplete/{ACTask.CC => ACTask.ZC} | 0 .../AutoComplete/{MakeAC.CC => MakeAC.ZC} | 0 .../BlkDev/{DiskCheck.CC => DiskCheck.ZC} | 0 .../BlkDev/{DiskPart.CC => DiskPart.ZC} | 0 src/System/BlkDev/{FileMgr.CC => FileMgr.ZC} | 0 .../BlkDev/{MakeZBlkDev.CC => MakeZBlkDev.ZC} | 0 src/System/BlkDev/{Mount.CC => Mount.ZC} | 14 +- src/System/BlkDev/{ZDiskA.CC => ZDiskA.ZC} | 4 +- src/System/BlkDev/{ZDiskB.CC => ZDiskB.ZC} | 0 src/System/Boot/BootDVD.CC | 183 ---------- src/System/Boot/BootDVDIns.CC | 35 -- src/System/Boot/BootHD.CC | 91 ----- src/System/Boot/BootHDIns.CC | 84 ----- src/System/Boot/BootMHD.CC | 105 ------ src/System/Boot/BootMHD2.CC | 121 ------- src/System/Boot/BootMHDIns.CC | 180 ---------- src/System/Boot/BootRAM.CC | 59 ---- src/System/Boot/DiskISORedSea.CC | 217 ------------ src/System/Boot/MakeBoot.CC | 8 - src/System/Ctrls/{CtrlsA.CC => CtrlsA.ZC} | 2 +- .../Ctrls/{CtrlsBttn.CC => CtrlsBttn.ZC} | 2 +- .../Ctrls/{CtrlsSlider.CC => CtrlsSlider.ZC} | 0 .../Ctrls/{MakeCtrls.CC => MakeCtrls.ZC} | 0 src/System/{Debug.CC => Debug.ZC} | 2 +- src/System/{Define.CC => Define.ZC} | 2 +- src/System/{DevInfo.CC => DevInfo.ZC} | 0 src/System/DolDoc/{DocBin.CC => DocBin.ZC} | 0 src/System/DolDoc/{DocChar.CC => DocChar.ZC} | 2 +- .../{DocClipBoard.CC => DocClipBoard.ZC} | 0 .../{DocCodeTools.CC => DocCodeTools.ZC} | 2 +- .../DolDoc/{DocDblBuf.CC => DocDblBuf.ZC} | 6 +- src/System/DolDoc/{DocEd.CC => DocEd.ZC} | 0 .../DolDoc/{DocExterns.CC => DocExterns.ZC} | 0 src/System/DolDoc/{DocFile.CC => DocFile.ZC} | 0 src/System/DolDoc/{DocFind.CC => DocFind.ZC} | 0 src/System/DolDoc/{DocForm.CC => DocForm.ZC} | 8 +- src/System/DolDoc/{DocGet.CC => DocGet.ZC} | 0 src/System/DolDoc/{DocGr.CC => DocGr.ZC} | 0 .../{DocHighlight.CC => DocHighlight.ZC} | 2 +- src/System/DolDoc/{DocInit.CC => DocInit.ZC} | 0 src/System/DolDoc/{DocLink.CC => DocLink.ZC} | 0 .../DolDoc/{DocMacro.CC => DocMacro.ZC} | 0 src/System/DolDoc/{DocNew.CC => DocNew.ZC} | 2 +- .../DolDoc/{DocPlain.CC => DocPlain.ZC} | 0 .../DolDoc/{DocPopUp.CC => DocPopUp.ZC} | 10 +- .../DolDoc/{DocPutKey.CC => DocPutKey.ZC} | 2 +- src/System/DolDoc/{DocPutS.CC => DocPutS.ZC} | 0 .../DolDoc/{DocRecalc.CC => DocRecalc.ZC} | 0 .../{DocRecalcLib.CC => DocRecalcLib.ZC} | 2 +- src/System/DolDoc/{DocRun.CC => DocRun.ZC} | 0 src/System/DolDoc/{DocTerm.CC => DocTerm.ZC} | 4 +- src/System/DolDoc/{DocTree.CC => DocTree.ZC} | 0 .../{DocWidgetWiz.CC => DocWidgetWiz.ZC} | 0 src/System/DolDoc/{MakeDoc.CC => MakeDoc.ZC} | 0 src/System/{Externs.CC => Externs.ZC} | 0 src/System/God/{GodBible.CC => GodBible.ZC} | 0 .../God/{GodExterns.CC => GodExterns.ZC} | 0 src/System/God/{GodSong.CC => GodSong.ZC} | 0 .../God/{HolySpirit.CC => HolySpirit.ZC} | 0 src/System/God/{MakeGod.CC => MakeGod.ZC} | 0 src/System/Gr/Gr.HH | 4 +- src/System/Gr/{GrAsm.CC => GrAsm.ZC} | 0 src/System/Gr/{GrBitMap.CC => GrBitMap.ZC} | 4 +- .../Gr/{GrComposites.CC => GrComposites.ZC} | 2 +- src/System/Gr/{GrDC.CC => GrDC.ZC} | 12 +- src/System/Gr/{GrEnd.CC => GrEnd.ZC} | 0 src/System/Gr/{GrExterns.CC => GrExterns.ZC} | 0 src/System/Gr/{GrGlobals.CC => GrGlobals.ZC} | 4 +- src/System/Gr/{GrInitA.CC => GrInitA.ZC} | 0 src/System/Gr/{GrInitB.CC => GrInitB.ZC} | 0 src/System/Gr/{GrMath.CC => GrMath.ZC} | 18 +- src/System/Gr/{GrPalette.CC => GrPalette.ZC} | 0 .../Gr/{GrPrimatives.CC => GrPrimatives.ZC} | 2 +- src/System/Gr/{GrScreen.CC => GrScreen.ZC} | 2 +- .../Gr/{GrSpritePlot.CC => GrSpritePlot.ZC} | 0 .../Gr/{GrTextBase.CC => GrTextBase.ZC} | 0 src/System/Gr/{MakeGr.CC => MakeGr.ZC} | 0 .../Gr/{ScreenCast.CC => ScreenCast.ZC} | 0 .../Gr/{SpriteBitMap.CC => SpriteBitMap.ZC} | 0 .../Gr/{SpriteCode.CC => SpriteCode.ZC} | 0 src/System/Gr/{SpriteEd.CC => SpriteEd.ZC} | 2 +- .../Gr/{SpriteMain.CC => SpriteMain.ZC} | 2 +- .../Gr/{SpriteMesh.CC => SpriteMesh.ZC} | 2 +- src/System/Gr/{SpriteNew.CC => SpriteNew.ZC} | 2 +- .../Gr/{SpriteSideBar.CC => SpriteSideBar.ZC} | 0 src/System/{Hash.CC => Hash.ZC} | 0 src/System/{InFile.CC => InFile.ZC} | 0 src/System/{MakeSystem.CC => MakeSystem.ZC} | 0 src/System/{Math.CC => Math.ZC} | 0 src/System/{MathODE.CC => MathODE.ZC} | 2 +- src/System/{Memory.CC => Memory.ZC} | 0 src/System/{Menu.CC => Menu.ZC} | 0 src/System/{Mouse.CC => Mouse.ZC} | Bin 1627 -> 1627 bytes src/System/{Registry.CC => Registry.ZC} | 14 +- src/System/{Sound.CC => Sound.ZC} | 0 .../{TaskSettings.CC => TaskSettings.ZC} | 0 src/System/{Training.CC => Training.ZC} | 0 src/System/Utils/{BinRep.CC => BinRep.ZC} | 2 +- src/System/Utils/{CPURep.CC => CPURep.ZC} | 0 ...onversionScript.CC => ConversionScript.ZC} | 4 +- src/System/Utils/{Diff.CC => Diff.ZC} | 0 src/System/Utils/{DocUtils.CC => DocUtils.ZC} | 0 src/System/Utils/{Find.CC => Find.ZC} | 0 src/System/Utils/{HeapLog.CC => HeapLog.ZC} | 0 src/System/Utils/{LineRep.CC => LineRep.ZC} | 0 .../Utils/{LinkCheck.CC => LinkCheck.ZC} | 0 .../Utils/{MakeUtils.CC => MakeUtils.ZC} | 0 src/System/Utils/{MemRep.CC => MemRep.ZC} | 0 src/System/Utils/{Merge.CC => Merge.ZC} | 0 src/System/Utils/{Profiler.CC => Profiler.ZC} | 2 +- src/System/Utils/{StrUtils.CC => StrUtils.ZC} | 0 src/System/Utils/{SysRep.CC => SysRep.ZC} | 0 src/System/Utils/{TaskRep.CC => TaskRep.ZC} | 0 src/System/Utils/{ToDolDoc.CC => ToDolDoc.ZC} | 0 src/System/Utils/{ToTXT.CC => ToTXT.ZC} | 0 src/System/Utils/{VideoRep.CC => VideoRep.ZC} | 0 src/System/{WallPaper.CC => WallPaper.ZC} | Bin src/System/{Win.CC => Win.ZC} | 0 src/System/{WinMgr.CC => WinMgr.ZC} | 0 src/System/{ZSplash.CC => ZSplash.ZC} | Bin 639 files changed, 733 insertions(+), 1804 deletions(-) rename src/Apps/Budget/{BgtAccts.CC => BgtAccts.ZC} (100%) rename src/Apps/Budget/{BgtEntry.CC => BgtEntry.ZC} (100%) rename src/Apps/Budget/{BgtFile.CC => BgtFile.ZC} (100%) rename src/Apps/Budget/{BgtMain.CC => BgtMain.ZC} (100%) rename src/Apps/Budget/{BgtStrs.CC => BgtStrs.ZC} (100%) rename src/Apps/Budget/{BgtTemplate.CC => BgtTemplate.ZC} (100%) rename src/Apps/Budget/{Budget.CC => Budget.ZC} (100%) rename src/Apps/Budget/{Install.CC => Install.ZC} (100%) rename src/Apps/Budget/{Load.CC => Load.ZC} (100%) rename src/Apps/Budget/{Run.CC => Run.ZC} (100%) rename src/Apps/GrModels/{BallGen.CC => BallGen.ZC} (96%) rename src/Apps/GrModels/{Load.CC => Load.ZC} (100%) rename src/Apps/GrModels/{ManGen.CC => ManGen.ZC} (98%) rename src/Apps/GrModels/{Models.CC => Models.ZC} (100%) rename src/Apps/GrModels/{Run.CC => Run.ZC} (100%) rename src/Apps/KeepAway/{KeepAway.CC => KeepAway.ZC} (99%) rename src/Apps/KeepAway/{Load.CC => Load.ZC} (100%) rename src/Apps/KeepAway/{Run.CC => Run.ZC} (100%) rename src/Apps/Logic/{Load.CC => Load.ZC} (100%) rename src/Apps/Logic/{Logic.CC => Logic.ZC} (100%) rename src/Apps/Logic/{Run.CC => Run.ZC} (100%) rename src/Apps/Psalmody/Examples/{childish.CC => childish.ZC} (100%) rename src/Apps/Psalmody/Examples/{night.CC => night.ZC} (100%) rename src/Apps/Psalmody/Examples/{prosper.CC => prosper.ZC} (100%) rename src/Apps/Psalmody/{Install.CC => Install.ZC} (100%) rename src/Apps/Psalmody/{JukeBox.CC => JukeBox.ZC} (99%) rename src/Apps/Psalmody/{JukePuppet.CC => JukePuppet.ZC} (100%) rename src/Apps/Psalmody/{Load.CC => Load.ZC} (100%) rename src/Apps/Psalmody/{Psalmody.CC => Psalmody.ZC} (100%) rename src/Apps/Psalmody/{PsalmodyCtrls.CC => PsalmodyCtrls.ZC} (100%) rename src/Apps/Psalmody/{PsalmodyDraw.CC => PsalmodyDraw.ZC} (100%) rename src/Apps/Psalmody/{PsalmodyFile.CC => PsalmodyFile.ZC} (99%) rename src/Apps/Psalmody/{PsalmodyMain.CC => PsalmodyMain.ZC} (100%) rename src/Apps/Psalmody/{Run.CC => Run.ZC} (100%) rename src/Apps/Span/{Install.CC => Install.ZC} (100%) rename src/Apps/Span/{Load.CC => Load.ZC} (100%) rename src/Apps/Span/{Run.CC => Run.ZC} (100%) rename src/Apps/Span/{SpanBridge.CC => SpanBridge.ZC} (100%) rename src/Apps/Span/{SpanDerive.CC => SpanDerive.ZC} (100%) rename src/Apps/Span/{SpanMain.CC => SpanMain.ZC} (100%) rename src/Apps/Span/{SpanNew.CC => SpanNew.ZC} (100%) rename src/Apps/Strut/{Load.CC => Load.ZC} (100%) rename src/Apps/Strut/{Run.CC => Run.ZC} (100%) rename src/Apps/Strut/{Strut.CC => Strut.ZC} (100%) rename src/Apps/TimeClock/{Install.CC => Install.ZC} (100%) rename src/Apps/TimeClock/{Load.CC => Load.ZC} (100%) rename src/Apps/TimeClock/{TimeClk.CC => TimeClk.ZC} (100%) rename src/Apps/Titanium/{Load.CC => Load.ZC} (100%) rename src/Apps/Titanium/{Run.CC => Run.ZC} (100%) rename src/Apps/Titanium/{Titanium.CC => Titanium.ZC} (100%) rename src/Apps/ToTheFront/AIs/{Human.CC => Human.ZC} (100%) rename src/Apps/ToTheFront/AIs/{SimpleAI.CC => SimpleAI.ZC} (100%) rename src/Apps/ToTheFront/{Install.CC => Install.ZC} (100%) rename src/Apps/ToTheFront/{Load.CC => Load.ZC} (100%) rename src/Apps/ToTheFront/{Run.CC => Run.ZC} (100%) rename src/Apps/ToTheFront/{TTFDraw.CC => TTFDraw.ZC} (100%) rename src/Apps/ToTheFront/{TTFFire.CC => TTFFire.ZC} (100%) rename src/Apps/ToTheFront/{TTFGlobals.CC => TTFGlobals.ZC} (100%) rename src/Apps/ToTheFront/{TTFInit.CC => TTFInit.ZC} (99%) rename src/Apps/ToTheFront/{TTFLib.CC => TTFLib.ZC} (100%) rename src/Apps/ToTheFront/{TTFMove.CC => TTFMove.ZC} (100%) rename src/Apps/ToTheFront/{TTFVis.CC => TTFVis.ZC} (100%) rename src/Apps/ToTheFront/{ToTheFront.CC => ToTheFront.ZC} (100%) rename src/Apps/Vocabulary/{Load.CC => Load.ZC} (100%) rename src/Apps/Vocabulary/{Run.CC => Run.ZC} (100%) rename src/Apps/Vocabulary/{VocabQuiz.CC => VocabQuiz.ZC} (100%) rename src/Apps/X-Caliber/{Load.CC => Load.ZC} (100%) rename src/Apps/X-Caliber/{Run.CC => Run.ZC} (100%) rename src/Apps/X-Caliber/{X-Caliber.CC => X-Caliber.ZC} (100%) rename src/Apps/X-Caliber/{XCCtrls.CC => XCCtrls.ZC} (100%) rename src/Compiler/{Asm.CC => Asm.ZC} (100%) rename src/Compiler/{AsmInit.CC => AsmInit.ZC} (100%) rename src/Compiler/{AsmLib.CC => AsmLib.ZC} (100%) rename src/Compiler/{AsmResolve.CC => AsmResolve.ZC} (100%) rename src/Compiler/{BackA.CC => BackA.ZC} (100%) rename src/Compiler/{BackB.CC => BackB.ZC} (100%) rename src/Compiler/{BackC.CC => BackC.ZC} (100%) rename src/Compiler/{BackFA.CC => BackFA.ZC} (100%) rename src/Compiler/{BackFB.CC => BackFB.ZC} (100%) rename src/Compiler/{BackLib.CC => BackLib.ZC} (100%) rename src/Compiler/{CExcept.CC => CExcept.ZC} (100%) rename src/Compiler/{CExterns.CC => CExterns.ZC} (100%) rename src/Compiler/{CHash.CC => CHash.ZC} (100%) rename src/Compiler/{CInit.CC => CInit.ZC} (100%) rename src/Compiler/{CMain.CC => CMain.ZC} (99%) rename src/Compiler/{CMisc.CC => CMisc.ZC} (100%) rename src/Compiler/{Lex.CC => Lex.ZC} (99%) rename src/Compiler/{LexLib.CC => LexLib.ZC} (99%) rename src/Compiler/{OptLib.CC => OptLib.ZC} (100%) rename src/Compiler/{OptPass012.CC => OptPass012.ZC} (99%) rename src/Compiler/{OptPass3.CC => OptPass3.ZC} (100%) rename src/Compiler/{OptPass4.CC => OptPass4.ZC} (99%) rename src/Compiler/{OptPass5.CC => OptPass5.ZC} (100%) rename src/Compiler/{OptPass6.CC => OptPass6.ZC} (100%) rename src/Compiler/{OptPass789A.CC => OptPass789A.ZC} (100%) rename src/Compiler/{ParseExp.CC => ParseExp.ZC} (100%) rename src/Compiler/{ParseLib.CC => ParseLib.ZC} (100%) rename src/Compiler/{ParseStatement.CC => ParseStatement.ZC} (100%) rename src/Compiler/{ParseVar.CC => ParseVar.ZC} (100%) rename src/Compiler/{Templates.CC => Templates.ZC} (100%) rename src/Compiler/{UAsm.CC => UAsm.ZC} (100%) rename src/Demo/AcctExample/{HomeKeyPlugIns.CC => HomeKeyPlugIns.ZC} (100%) rename src/Demo/AcctExample/{HomeLocalize.CC => HomeLocalize.ZC} (100%) rename src/Demo/AcctExample/{HomeSys.CC => HomeSys.ZC} (100%) rename src/Demo/AcctExample/{HomeWrappers.CC => HomeWrappers.ZC} (100%) rename src/Demo/AcctExample/{MakeHome.CC => MakeHome.ZC} (100%) rename src/Demo/AcctExample/{Once.CC => Once.ZC} (87%) rename src/Demo/AcctExample/{Registry.CC => Registry.ZC} (100%) rename src/Demo/AcctExample/TOS/{MakeTOS.CC => MakeTOS.ZC} (100%) rename src/Demo/AcctExample/TOS/{TOSConfig.CC => TOSConfig.ZC} (100%) rename src/Demo/AcctExample/TOS/{TOSDistro.CC => TOSDistro.ZC} (91%) rename src/Demo/AcctExample/TOS/{TOSExtern.CC => TOSExtern.ZC} (100%) rename src/Demo/AcctExample/TOS/{TOSMisc.CC => TOSMisc.ZC} (100%) rename src/Demo/AcctExample/TOS/{TOSTheme.CC => TOSTheme.ZC} (100%) rename src/Demo/Asm/{AsmAndC1.CC => AsmAndC1.ZC} (100%) rename src/Demo/Asm/{AsmAndC2.CC => AsmAndC2.ZC} (96%) rename src/Demo/Asm/{AsmAndC3.CC => AsmAndC3.ZC} (100%) rename src/Demo/Asm/{AsmHelloWorld.CC => AsmHelloWorld.ZC} (95%) rename src/Demo/Asm/{BuzzFizz.CC => BuzzFizz.ZC} (100%) rename src/Demo/Asm/{DivByHand.CC => DivByHand.ZC} (100%) rename src/Demo/Asm/{MulByHand.CC => MulByHand.ZC} (100%) rename src/Demo/Asm/{PutDec.CC => PutDec.ZC} (100%) rename src/Demo/{Carry.CC => Carry.ZC} (100%) rename src/Demo/{ClassMeta.CC => ClassMeta.ZC} (97%) rename src/Demo/{CompileDemo.CC => CompileDemo.ZC} (100%) rename src/Demo/{DateTime.CC => DateTime.ZC} (100%) rename src/Demo/{DebugDemo.CC => DebugDemo.ZC} (100%) rename src/Demo/{Define.CC => Define.ZC} (100%) rename src/Demo/{Directives.CC => Directives.ZC} (100%) rename src/Demo/Disk/{DataBase.CC => DataBase.ZC} (100%) rename src/Demo/Disk/{DiskRaw.CC => DiskRaw.ZC} (100%) rename src/Demo/Disk/{FPrintF.CC => FPrintF.ZC} (100%) rename src/Demo/Disk/{SerializeTree.CC => SerializeTree.ZC} (100%) rename src/Demo/Disk/{UnusedSpaceRep.CC => UnusedSpaceRep.ZC} (100%) rename src/Demo/DolDoc/{CallBack.CC => CallBack.ZC} (97%) rename src/Demo/DolDoc/{ClickCallBack.CC => ClickCallBack.ZC} (95%) rename src/Demo/DolDoc/{CursorMove.CC => CursorMove.ZC} (100%) rename src/Demo/DolDoc/{Data.CC => Data.ZC} (95%) rename src/Demo/DolDoc/{DefineStr.CC => DefineStr.ZC} (100%) rename src/Demo/DolDoc/{FileRead.CC => FileRead.ZC} (95%) rename src/Demo/DolDoc/{Form.CC => Form.ZC} (100%) rename src/Demo/DolDoc/{MenuBttn.CC => MenuBttn.ZC} (100%) rename src/Demo/DolDoc/{MenuSprite.CC => MenuSprite.ZC} (100%) rename src/Demo/DolDoc/{NumBible.CC => NumBible.ZC} (100%) rename src/Demo/DolDoc/{TextDemo.CC => TextDemo.ZC} (85%) rename src/Demo/DolDoc/{TreeDemo.CC => TreeDemo.ZC} (100%) rename src/Demo/DolDoc/{UnusedDefine.CC => UnusedDefine.ZC} (100%) rename src/Demo/{Exceptions.CC => Exceptions.ZC} (100%) rename src/Demo/{ExtChars.CC => ExtChars.ZC} (77%) rename src/Demo/Games/{BattleLines.CC => BattleLines.ZC} (99%) rename src/Demo/Games/{BigGuns.CC => BigGuns.ZC} (98%) rename src/Demo/Games/{BlackDiamond.CC => BlackDiamond.ZC} (100%) rename src/Demo/Games/{BomberGolf.CC => BomberGolf.ZC} (100%) rename src/Demo/Games/{CastleFrankenstein.CC => CastleFrankenstein.ZC} (99%) rename src/Demo/Games/{CharDemo.CC => CharDemo.ZC} (97%) rename src/Demo/Games/{Chess.CC => Chess.ZC} (100%) rename src/Demo/Games/{CircleTrace.CC => CircleTrace.ZC} (100%) rename src/Demo/Games/{Collision.CC => Collision.ZC} (96%) rename src/Demo/Games/{Digits.CC => Digits.ZC} (96%) rename src/Demo/Games/{DunGen.CC => DunGen.ZC} (99%) rename src/Demo/Games/{ElephantWalk.CC => ElephantWalk.ZC} (100%) rename src/Demo/Games/{FlapBat.CC => FlapBat.ZC} (100%) rename src/Demo/Games/{FlatTops.CC => FlatTops.ZC} (100%) rename src/Demo/Games/{Halogen.CC => Halogen.ZC} (100%) rename src/Demo/Games/{MassSpring.CC => MassSpring.ZC} (100%) rename src/Demo/Games/{Maze.CC => Maze.ZC} (100%) rename src/Demo/Games/{RainDrops.CC => RainDrops.ZC} (100%) rename src/Demo/Games/{RawHide.CC => RawHide.ZC} (99%) rename src/Demo/Games/{Rocket.CC => Rocket.ZC} (100%) rename src/Demo/Games/{RocketScience.CC => RocketScience.ZC} (100%) rename src/Demo/Games/{Squirt.CC => Squirt.ZC} (100%) rename src/Demo/Games/Stadium/{Stadium.CC => Stadium.ZC} (100%) rename src/Demo/Games/Stadium/{StadiumGen.CC => StadiumGen.ZC} (100%) rename src/Demo/Games/{Talons.CC => Talons.ZC} (99%) rename src/Demo/Games/{TheDead.CC => TheDead.ZC} (100%) rename src/Demo/Games/{TicTacToe.CC => TicTacToe.ZC} (100%) rename src/Demo/Games/{TreeCheckers.CC => TreeCheckers.ZC} (100%) rename src/Demo/Games/{Varoom.CC => Varoom.ZC} (100%) rename src/Demo/Games/{Wenceslas.CC => Wenceslas.ZC} (100%) rename src/Demo/Games/{Whap.CC => Whap.ZC} (100%) rename src/Demo/Games/{Zing.CC => Zing.ZC} (100%) rename src/Demo/Games/{ZoneOut.CC => ZoneOut.ZC} (100%) rename src/Demo/{GlobalVars.CC => GlobalVars.ZC} (100%) rename src/Demo/Graphics/{32BitColor.CC => 32BitColor.ZC} (100%) rename src/Demo/Graphics/{32BitPaint.CC => 32BitPaint.ZC} (100%) rename src/Demo/Graphics/{3DPoly.CC => 3DPoly.ZC} (100%) rename src/Demo/Graphics/{BSpline.CC => BSpline.ZC} (100%) rename src/Demo/Graphics/{Blot.CC => Blot.ZC} (100%) rename src/Demo/Graphics/{Bounce.CC => Bounce.ZC} (98%) rename src/Demo/Graphics/{Box.CC => Box.ZC} (100%) rename src/Demo/Graphics/{Cartesian.CC => Cartesian.ZC} (96%) rename src/Demo/Graphics/{CharAnimation.CC => CharAnimation.ZC} (78%) rename src/Demo/Graphics/{Clock.CC => Clock.ZC} (100%) rename src/Demo/Graphics/{Collision.CC => Collision.ZC} (100%) rename src/Demo/Graphics/{CommonAncestor.CC => CommonAncestor.ZC} (98%) rename src/Demo/Graphics/{Doodle.CC => Doodle.ZC} (100%) rename src/Demo/Graphics/{EdSprite.CC => EdSprite.ZC} (100%) rename src/Demo/Graphics/{Elephant.CC => Elephant.ZC} (100%) rename src/Demo/Graphics/{Extents.CC => Extents.ZC} (100%) rename src/Demo/Graphics/{FontEd.CC => FontEd.ZC} (94%) rename src/Demo/Graphics/{GrDir.CC => GrDir.ZC} (97%) rename src/Demo/Graphics/{Grid.CC => Grid.ZC} (100%) rename src/Demo/Graphics/{Hanoi.CC => Hanoi.ZC} (100%) rename src/Demo/Graphics/{Lattice.CC => Lattice.ZC} (100%) rename src/Demo/Graphics/{Life.CC => Life.ZC} (100%) rename src/Demo/Graphics/{LightTable.CC => LightTable.ZC} (100%) rename src/Demo/Graphics/{Lines.CC => Lines.ZC} (100%) rename src/Demo/Graphics/{LowPassFilter.CC => LowPassFilter.ZC} (100%) rename src/Demo/Graphics/{MathAudioDemo.CC => MathAudioDemo.ZC} (100%) rename src/Demo/Graphics/{MouseDemo.CC => MouseDemo.ZC} (100%) rename src/Demo/Graphics/{NetOfDots.CC => NetOfDots.ZC} (100%) rename src/Demo/Graphics/{Palette.CC => Palette.ZC} (100%) rename src/Demo/Graphics/{PanText.CC => PanText.ZC} (100%) rename src/Demo/Graphics/{Pick.CC => Pick.ZC} (100%) rename src/Demo/Graphics/{Pick3D.CC => Pick3D.ZC} (100%) rename src/Demo/Graphics/{PoleZeros.CC => PoleZeros.ZC} (100%) rename src/Demo/Graphics/{PredatorPrey.CC => PredatorPrey.ZC} (100%) rename src/Demo/Graphics/{RotateTank.CC => RotateTank.ZC} (100%) rename src/Demo/Graphics/{ScreenCapture.CC => ScreenCapture.ZC} (80%) rename src/Demo/Graphics/{ScrollBars.CC => ScrollBars.ZC} (100%) rename src/Demo/Graphics/{Shading.CC => Shading.ZC} (99%) rename src/Demo/Graphics/{Shadow.CC => Shadow.ZC} (100%) rename src/Demo/Graphics/{Slider.CC => Slider.ZC} (100%) rename src/Demo/Graphics/{Speedline.CC => Speedline.ZC} (100%) rename src/Demo/Graphics/{SpritePlot.CC => SpritePlot.ZC} (100%) rename src/Demo/Graphics/{SpritePlot3D.CC => SpritePlot3D.ZC} (100%) rename src/Demo/Graphics/{SpritePut.CC => SpritePut.ZC} (99%) rename src/Demo/Graphics/{SpritePutExt.CC => SpritePutExt.ZC} (84%) rename src/Demo/Graphics/{SpriteRaw.CC => SpriteRaw.ZC} (100%) rename src/Demo/Graphics/{SpriteText.CC => SpriteText.ZC} (100%) rename src/Demo/Graphics/{SunMoon.CC => SunMoon.ZC} (100%) rename src/Demo/Graphics/{Symmetry.CC => Symmetry.ZC} (100%) rename src/Demo/Graphics/{Transform.CC => Transform.ZC} (100%) rename src/Demo/Graphics/{WallPaperCtrl.CC => WallPaperCtrl.ZC} (97%) rename src/Demo/Graphics/{WallPaperFish.CC => WallPaperFish.ZC} (100%) rename src/Demo/Graphics/{WallPaperStars.CC => WallPaperStars.ZC} (100%) rename src/Demo/Graphics/{WinZBuf.CC => WinZBuf.ZC} (100%) rename src/Demo/InFile/{InPopUp.CC => InPopUp.ZC} (100%) rename src/Demo/InFile/{InSetIP.CC => InSetIP.ZC} (100%) rename src/Demo/{KeyBitMap.CC => KeyBitMap.ZC} (100%) rename src/Demo/{LastClass.CC => LastClass.ZC} (92%) rename src/Demo/Lectures/{AndNotMod.CC => AndNotMod.ZC} (100%) rename src/Demo/Lectures/{FixedPoint.CC => FixedPoint.ZC} (95%) rename src/Demo/Lectures/{FixedPointAdvanced.CC => FixedPointAdvanced.ZC} (98%) rename src/Demo/Lectures/{InterruptDemo.CC => InterruptDemo.ZC} (100%) rename src/Demo/Lectures/{MiniCompiler.CC => MiniCompiler.ZC} (94%) rename src/Demo/Lectures/{MiniGrLib.CC => MiniGrLib.ZC} (100%) rename src/Demo/Lectures/{NegDisp.CC => NegDisp.ZC} (100%) rename src/Demo/Lectures/{Optimization.CC => Optimization.ZC} (100%) rename src/Demo/Lectures/{PCIInterrupts.CC => PCIInterrupts.ZC} (100%) rename src/Demo/Lectures/{Ring3.CC => Ring3.ZC} (100%) rename src/Demo/{MagicPairs.CC => MagicPairs.ZC} (100%) rename src/Demo/{MemDemo.CC => MemDemo.ZC} (100%) rename src/Demo/{MessageLoop.CC => MessageLoop.ZC} (100%) rename src/Demo/MultiCore/{Interrupts.CC => Interrupts.ZC} (100%) rename src/Demo/MultiCore/{LoadTest.CC => LoadTest.ZC} (93%) rename src/Demo/MultiCore/{Lock.CC => Lock.ZC} (100%) rename src/Demo/MultiCore/{MPAdd.CC => MPAdd.ZC} (100%) rename src/Demo/MultiCore/{MPPrint.CC => MPPrint.ZC} (100%) rename src/Demo/MultiCore/{MPRadix.CC => MPRadix.ZC} (100%) rename src/Demo/MultiCore/{Palindrome.CC => Palindrome.ZC} (100%) rename src/Demo/MultiCore/{Primes.CC => Primes.ZC} (100%) rename src/Demo/{NullCase.CC => NullCase.ZC} (100%) rename src/Demo/{OnceDemo.CC => OnceDemo.ZC} (100%) rename src/Demo/{ParenWarn.CC => ParenWarn.ZC} (100%) rename src/Demo/{PhoneNumWords.CC => PhoneNumWords.ZC} (100%) rename src/Demo/{Print.CC => Print.ZC} (100%) rename src/Demo/{Progress.CC => Progress.ZC} (100%) rename src/Demo/{Prompt.CC => Prompt.ZC} (100%) rename src/Demo/{PullDownMenu.CC => PullDownMenu.ZC} (100%) rename src/Demo/{RadixSort.CC => RadixSort.ZC} (100%) rename src/Demo/{RandDemo.CC => RandDemo.ZC} (94%) rename src/Demo/{RegistryDemo.CC => RegistryDemo.ZC} (95%) rename src/Demo/RevFileDemo/{Rev.CC => Rev.ZC} (100%) rename src/Demo/{ScreenCodes.CC => ScreenCodes.ZC} (83%) rename src/Demo/SortFileDemo/{F64FileGen.CC => F64FileGen.ZC} (98%) rename src/Demo/SortFileDemo/{F64FileSort.CC => F64FileSort.ZC} (99%) rename src/Demo/Sound/{ASCIIOrgan.CC => ASCIIOrgan.ZC} (100%) rename src/Demo/Sound/{MorseCode.CC => MorseCode.ZC} (100%) rename src/Demo/Sound/{OhGreat.CC => OhGreat.ZC} (100%) rename src/Demo/Sound/{WaterFowl.CC => WaterFowl.ZC} (100%) rename src/Demo/{Spy.CC => Spy.ZC} (100%) rename src/Demo/{StackGrow.CC => StackGrow.ZC} (100%) rename src/Demo/{SubIntAccess.CC => SubIntAccess.ZC} (93%) rename src/Demo/{SubSwitch.CC => SubSwitch.ZC} (100%) rename src/Demo/{SuggestSpelling.CC => SuggestSpelling.ZC} (100%) rename src/Demo/Templates/{Game1.CC => Game1.ZC} (100%) rename src/Demo/Templates/{Lex1.CC => Lex1.ZC} (100%) rename src/Demo/Templates/{MultiCore1.CC => MultiCore1.ZC} (100%) rename src/Demo/Templates/{ODE1.CC => ODE1.ZC} (100%) rename src/Demo/Templates/{Registry1.CC => Registry1.ZC} (100%) rename src/Demo/Templates/{Util1.CC => Util1.ZC} (100%) rename src/Demo/Templates/{Util2.CC => Util2.ZC} (100%) rename src/Demo/{TimeIns.CC => TimeIns.ZC} (100%) rename src/Demo/ToHtmlToTXTDemo/{HtmlDirList.CC => HtmlDirList.ZC} (100%) rename src/Demo/ToHtmlToTXTDemo/{HtmlGen.CC => HtmlGen.ZC} (73%) rename src/Demo/ToHtmlToTXTDemo/{TXTGen.CC => TXTGen.ZC} (100%) rename src/Demo/ToHtmlToTXTDemo/{ToHtml.CC => ToHtml.ZC} (99%) rename src/Demo/WebLogDemo/{WebLogRep.CC => WebLogRep.ZC} (100%) rename src/Demo/WebLogDemo/{WebLogScramble.CC => WebLogScramble.ZC} (100%) rename src/Demo/{WordSearch.CC => WordSearch.ZC} (98%) rename src/Doc/{Comm.CC => Comm.ZC} (100%) rename src/Home/{DoDistro.CC => DoDistro.ZC} (90%) rename src/Home/{HtmlGen.CC => HtmlGen.ZC} (93%) rename src/Home/{K.CC => K.ZC} (90%) rename src/Home/Net/Drivers/{E1000.CC => E1000.ZC} (100%) rename src/Home/Net/Drivers/{PCNet.CC => PCNet.ZC} (99%) rename src/Home/Net/Drivers/{Run.CC => Run.ZC} (100%) rename src/Home/Net/Drivers/{VirtIONet.CC => VirtIONet.ZC} (100%) rename src/Home/Net/{Load.CC => Load.ZC} (100%) rename src/Home/Net/Programs/{Gopher.CC => Gopher.ZC} (98%) rename src/Home/Net/Programs/{TCPChatClient.CC => TCPChatClient.ZC} (100%) rename src/Home/Net/Programs/{TCPChatServer.CC => TCPChatServer.ZC} (100%) rename src/Home/Net/Programs/{UDPChat.CC => UDPChat.ZC} (100%) rename src/Home/Net/Protocols/{ARP.CC => ARP.ZC} (100%) rename src/Home/Net/Protocols/{DHCP.CC => DHCP.ZC} (100%) rename src/Home/Net/Protocols/{DNS.CC => DNS.ZC} (100%) rename src/Home/Net/Protocols/{Ethernet.CC => Ethernet.ZC} (100%) rename src/Home/Net/Protocols/{ICMP.CC => ICMP.ZC} (100%) rename src/Home/Net/Protocols/{IPV4.CC => IPV4.ZC} (100%) rename src/Home/Net/Protocols/{Sockets.CC => Sockets.ZC} (100%) rename src/Home/Net/Protocols/TCP/{MakeTCP.CC => MakeTCP.ZC} (75%) rename src/Home/Net/Protocols/TCP/{TCP.CC => TCP.ZC} (100%) rename src/Home/Net/Protocols/TCP/{TCPHandler.CC => TCPHandler.ZC} (100%) rename src/Home/Net/Protocols/TCP/{TCPTree.CC => TCPTree.ZC} (100%) rename src/Home/Net/Protocols/UDP/{MakeUDP.CC => MakeUDP.ZC} (67%) rename src/Home/Net/Protocols/UDP/{UDP.CC => UDP.ZC} (100%) rename src/Home/Net/Protocols/UDP/{UDPTree.CC => UDPTree.ZC} (100%) rename src/Home/Net/{Start.CC => Start.ZC} (100%) rename src/Home/Net/Tests/{ARPTest.CC => ARPTest.ZC} (100%) rename src/Home/Net/Tests/{DHCPTest0.CC => DHCPTest0.ZC} (100%) rename src/Home/Net/Tests/{DHCPTest1.CC => DHCPTest1.ZC} (100%) rename src/Home/Net/Tests/{DHCPTest2.CC => DHCPTest2.ZC} (92%) rename src/Home/Net/Tests/{DNSTest.CC => DNSTest.ZC} (100%) rename src/Home/Net/Tests/{EthernetTest.CC => EthernetTest.ZC} (100%) rename src/Home/Net/Tests/{HostTest0.CC => HostTest0.ZC} (100%) rename src/Home/Net/Tests/{HostTest1.CC => HostTest1.ZC} (100%) rename src/Home/Net/Tests/{ICMPTest.CC => ICMPTest.ZC} (100%) rename src/Home/Net/Tests/{IPV4Test.CC => IPV4Test.ZC} (100%) rename src/Home/Net/Tests/{PCNetTest.CC => PCNetTest.ZC} (100%) rename src/Home/Net/Tests/{PCP.CC => PCP.ZC} (100%) rename src/Home/Net/Tests/{TCPEchoClient.CC => TCPEchoClient.ZC} (100%) rename src/Home/Net/Tests/{TCPEchoServer.CC => TCPEchoServer.ZC} (100%) rename src/Home/Net/Tests/{TCPTest0.CC => TCPTest0.ZC} (100%) rename src/Home/Net/Tests/{TCPTest1.CC => TCPTest1.ZC} (100%) rename src/Home/Net/Tests/{TCPTest2.CC => TCPTest2.ZC} (100%) rename src/Home/Net/Tests/{UDPSocketTest0.CC => UDPSocketTest0.ZC} (100%) rename src/Home/Net/Tests/{UDPSocketTest1.CC => UDPSocketTest1.ZC} (100%) rename src/Home/Net/Tests/{UDPSocketTest2.CC => UDPSocketTest2.ZC} (100%) rename src/Home/Net/Tests/{UDPTest0.CC => UDPTest0.ZC} (100%) rename src/Home/Net/Tests/{UDPTest1.CC => UDPTest1.ZC} (100%) rename src/Home/Net/Utilities/{BST.CC => BST.ZC} (100%) rename src/Home/Net/Utilities/JSON/{JSON.CC => JSON.ZC} (100%) rename src/Home/Net/Utilities/{NetHandler.CC => NetHandler.ZC} (100%) rename src/Home/Net/Utilities/{NetLog.CC => NetLog.ZC} (100%) rename src/Home/Net/Utilities/{NetQueue.CC => NetQueue.ZC} (100%) rename src/Home/PaletteEditor/{Load.CC => Load.ZC} (100%) rename src/Home/PaletteEditor/{PaletteEdit.CC => PaletteEdit.ZC} (99%) rename src/Home/PaletteEditor/{PaletteGod.CC => PaletteGod.ZC} (100%) rename src/Home/PaletteEditor/{PaletteSelect.CC => PaletteSelect.ZC} (90%) rename src/Home/PaletteEditor/Palettes/{Commander.CC => Commander.ZC} (100%) rename src/Home/PaletteEditor/Palettes/{Green.CC => Green.ZC} (100%) rename src/Home/PaletteEditor/Palettes/{Marine.CC => Marine.ZC} (100%) rename src/Home/PaletteEditor/Palettes/{Slate.CC => Slate.ZC} (100%) rename src/Home/PaletteEditor/Palettes/{Temple.CC => Temple.ZC} (100%) rename src/Home/PaletteEditor/Palettes/{Zsnes.CC => Zsnes.ZC} (100%) rename src/Home/PaletteEditor/{Run.CC => Run.ZC} (100%) rename src/Home/{SSE.CC => SSE.ZC} (100%) rename src/{HomeKeyPlugIns.CC => HomeKeyPlugIns.ZC} (100%) rename src/{HomeLocalize.CC => HomeLocalize.ZC} (100%) rename src/{HomeSys.CC => HomeSys.ZC} (94%) rename src/{HomeWrappers.CC => HomeWrappers.ZC} (100%) rename src/Kernel/BlkDev/{DiskAHCI.CC => DiskAHCI.ZC} (100%) rename src/Kernel/BlkDev/{DiskATAId.CC => DiskATAId.ZC} (97%) rename src/Kernel/BlkDev/{DiskAddDev.CC => DiskAddDev.ZC} (100%) rename src/Kernel/BlkDev/{DiskBlk.CC => DiskBlk.ZC} (100%) rename src/Kernel/BlkDev/{DiskBlkDev.CC => DiskBlkDev.ZC} (100%) rename src/Kernel/BlkDev/{DiskCDDVD.CC => DiskCDDVD.ZC} (100%) rename src/Kernel/BlkDev/{DiskCFile.CC => DiskCFile.ZC} (100%) rename src/Kernel/BlkDev/{DiskCache.CC => DiskCache.ZC} (100%) rename src/Kernel/BlkDev/{DiskClus.CC => DiskClus.ZC} (100%) rename src/Kernel/BlkDev/{DiskCopy.CC => DiskCopy.ZC} (100%) rename src/Kernel/BlkDev/{DiskDirA.CC => DiskDirA.ZC} (100%) rename src/Kernel/BlkDev/{DiskDirB.CC => DiskDirB.ZC} (100%) rename src/Kernel/BlkDev/{DiskDirContext.CC => DiskDirContext.ZC} (100%) rename src/Kernel/BlkDev/{DiskDrive.CC => DiskDrive.ZC} (100%) rename src/Kernel/BlkDev/{DiskFile.CC => DiskFile.ZC} (100%) rename src/Kernel/BlkDev/{DiskFind.CC => DiskFind.ZC} (100%) rename src/Kernel/BlkDev/{DiskFormat.CC => DiskFormat.ZC} (100%) rename src/Kernel/BlkDev/{DiskStrA.CC => DiskStrA.ZC} (98%) rename src/Kernel/BlkDev/{DiskStrB.CC => DiskStrB.ZC} (100%) rename src/Kernel/BlkDev/{FileSysFAT.CC => FileSysFAT.ZC} (100%) rename src/Kernel/BlkDev/{FileSysRedSea.CC => FileSysRedSea.ZC} (100%) rename src/Kernel/BlkDev/{MakeBlkDev.CC => MakeBlkDev.ZC} (100%) rename src/Kernel/{Display.CC => Display.ZC} (100%) rename src/Kernel/{EdLite.CC => EdLite.ZC} (99%) rename src/Kernel/{FontStd.CC => FontStd.ZC} (100%) rename src/Kernel/{FunSeg.CC => FunSeg.ZC} (100%) rename src/Kernel/{Job.CC => Job.ZC} (99%) rename src/Kernel/{KConfig.CC => KConfig.ZC} (100%) rename src/Kernel/{KDataTypes.CC => KDataTypes.ZC} (100%) rename src/Kernel/{KDate.CC => KDate.ZC} (100%) rename src/Kernel/{KDebug.CC => KDebug.ZC} (99%) rename src/Kernel/{KDefine.CC => KDefine.ZC} (100%) rename src/Kernel/{KExcept.CC => KExcept.ZC} (100%) rename src/Kernel/{KExterns.CC => KExterns.ZC} (100%) rename src/Kernel/{KGlobals.CC => KGlobals.ZC} (88%) rename src/Kernel/{KHashA.CC => KHashA.ZC} (100%) rename src/Kernel/{KHashB.CC => KHashB.ZC} (99%) rename src/Kernel/{KInterrupts.CC => KInterrupts.ZC} (97%) rename src/Kernel/{KLoad.CC => KLoad.ZC} (98%) rename src/Kernel/{KMain.CC => KMain.ZC} (97%) rename src/Kernel/{KMathA.CC => KMathA.ZC} (100%) rename src/Kernel/{KMathB.CC => KMathB.ZC} (100%) rename src/Kernel/{KMisc.CC => KMisc.ZC} (99%) rename src/Kernel/{KStart16.CC => KStart16.ZC} (92%) rename src/Kernel/{KStart32.CC => KStart32.ZC} (97%) rename src/Kernel/{KStart64.CC => KStart64.ZC} (97%) rename src/Kernel/{KTask.CC => KTask.ZC} (98%) rename src/Kernel/{KUtils.CC => KUtils.ZC} (100%) rename src/Kernel/{KeyDev.CC => KeyDev.ZC} (100%) rename src/Kernel/Memory/{BlkPool.CC => BlkPool.ZC} (96%) rename src/Kernel/Memory/{HeapCtrl.CC => HeapCtrl.ZC} (92%) rename src/Kernel/Memory/{MAllocFree.CC => MAllocFree.ZC} (99%) rename src/Kernel/Memory/{MakeMemory.CC => MakeMemory.ZC} (100%) rename src/Kernel/Memory/{MemPag.CC => MemPag.ZC} (100%) rename src/Kernel/Memory/{MemPhysical.CC => MemPhysical.ZC} (100%) rename src/Kernel/Memory/{PageTables.CC => PageTables.ZC} (100%) rename src/Kernel/{MultiProc.CC => MultiProc.ZC} (97%) rename src/Kernel/{PCI.CC => PCI.ZC} (100%) rename src/Kernel/{PCIBIOS.CC => PCIBIOS.ZC} (100%) rename src/Kernel/{QuickSort.CC => QuickSort.ZC} (96%) rename src/Kernel/{Sched.CC => Sched.ZC} (100%) rename src/Kernel/SerialDev/{Keyboard.CC => Keyboard.ZC} (100%) rename src/Kernel/SerialDev/{MakeSerialDev.CC => MakeSerialDev.ZC} (100%) rename src/Kernel/SerialDev/{Message.CC => Message.ZC} (99%) rename src/Kernel/SerialDev/{Mouse.CC => Mouse.ZC} (99%) rename src/Kernel/{StrA.CC => StrA.ZC} (100%) rename src/Kernel/{StrB.CC => StrB.ZC} (98%) rename src/Kernel/{StrPrint.CC => StrPrint.ZC} (100%) rename src/Kernel/{StrScan.CC => StrScan.ZC} (100%) rename src/{MakeHome.CC => MakeHome.ZC} (100%) rename src/Misc/Auto/{AutoDistro.CC => AutoDistro.ZC} (90%) rename src/Misc/Auto/{AutoFullDistro0.CC => AutoFullDistro0.ZC} (100%) rename src/Misc/Auto/{AutoFullDistro1.CC => AutoFullDistro1.ZC} (100%) rename src/Misc/Auto/{AutoFullDistro2.CC => AutoFullDistro2.ZC} (94%) rename src/Misc/Auto/{AutoInstall.CC => AutoInstall.ZC} (91%) rename src/Misc/Auto/{BootMHD2.CC => BootMHD2.ZC} (97%) rename src/Misc/Auto/{HomeSys.CC => HomeSys.ZC} (100%) rename src/Misc/Auto/{Once.CC => Once.ZC} (83%) rename src/Misc/{DoDistro.CC => DoDistro.ZC} (92%) rename src/Misc/{OSInstall.CC => OSInstall.ZC} (97%) rename src/Misc/{OSTestSuite.CC => OSTestSuite.ZC} (100%) rename src/{Once.CC => Once.ZC} (93%) rename src/{StartOS.CC => StartOS.ZC} (94%) rename src/System/AutoComplete/{ACDictGen.CC => ACDictGen.ZC} (100%) rename src/System/AutoComplete/{ACFill.CC => ACFill.ZC} (100%) rename src/System/AutoComplete/{ACInit.CC => ACInit.ZC} (100%) rename src/System/AutoComplete/{ACTask.CC => ACTask.ZC} (100%) rename src/System/AutoComplete/{MakeAC.CC => MakeAC.ZC} (100%) rename src/System/BlkDev/{DiskCheck.CC => DiskCheck.ZC} (100%) rename src/System/BlkDev/{DiskPart.CC => DiskPart.ZC} (100%) rename src/System/BlkDev/{FileMgr.CC => FileMgr.ZC} (100%) rename src/System/BlkDev/{MakeZBlkDev.CC => MakeZBlkDev.ZC} (100%) rename src/System/BlkDev/{Mount.CC => Mount.ZC} (97%) rename src/System/BlkDev/{ZDiskA.CC => ZDiskA.ZC} (98%) rename src/System/BlkDev/{ZDiskB.CC => ZDiskB.ZC} (100%) delete mode 100755 src/System/Boot/BootDVD.CC delete mode 100755 src/System/Boot/BootDVDIns.CC delete mode 100755 src/System/Boot/BootHD.CC delete mode 100755 src/System/Boot/BootHDIns.CC delete mode 100755 src/System/Boot/BootMHD.CC delete mode 100755 src/System/Boot/BootMHD2.CC delete mode 100755 src/System/Boot/BootMHDIns.CC delete mode 100755 src/System/Boot/BootRAM.CC delete mode 100755 src/System/Boot/DiskISORedSea.CC delete mode 100755 src/System/Boot/MakeBoot.CC rename src/System/Ctrls/{CtrlsA.CC => CtrlsA.ZC} (99%) rename src/System/Ctrls/{CtrlsBttn.CC => CtrlsBttn.ZC} (97%) rename src/System/Ctrls/{CtrlsSlider.CC => CtrlsSlider.ZC} (100%) rename src/System/Ctrls/{MakeCtrls.CC => MakeCtrls.ZC} (100%) rename src/System/{Debug.CC => Debug.ZC} (99%) rename src/System/{Define.CC => Define.ZC} (95%) rename src/System/{DevInfo.CC => DevInfo.ZC} (100%) rename src/System/DolDoc/{DocBin.CC => DocBin.ZC} (100%) rename src/System/DolDoc/{DocChar.CC => DocChar.ZC} (99%) rename src/System/DolDoc/{DocClipBoard.CC => DocClipBoard.ZC} (100%) rename src/System/DolDoc/{DocCodeTools.CC => DocCodeTools.ZC} (99%) rename src/System/DolDoc/{DocDblBuf.CC => DocDblBuf.ZC} (97%) rename src/System/DolDoc/{DocEd.CC => DocEd.ZC} (100%) rename src/System/DolDoc/{DocExterns.CC => DocExterns.ZC} (100%) rename src/System/DolDoc/{DocFile.CC => DocFile.ZC} (100%) rename src/System/DolDoc/{DocFind.CC => DocFind.ZC} (100%) rename src/System/DolDoc/{DocForm.CC => DocForm.ZC} (97%) rename src/System/DolDoc/{DocGet.CC => DocGet.ZC} (100%) rename src/System/DolDoc/{DocGr.CC => DocGr.ZC} (100%) rename src/System/DolDoc/{DocHighlight.CC => DocHighlight.ZC} (98%) rename src/System/DolDoc/{DocInit.CC => DocInit.ZC} (100%) rename src/System/DolDoc/{DocLink.CC => DocLink.ZC} (100%) rename src/System/DolDoc/{DocMacro.CC => DocMacro.ZC} (100%) rename src/System/DolDoc/{DocNew.CC => DocNew.ZC} (99%) rename src/System/DolDoc/{DocPlain.CC => DocPlain.ZC} (100%) rename src/System/DolDoc/{DocPopUp.CC => DocPopUp.ZC} (98%) rename src/System/DolDoc/{DocPutKey.CC => DocPutKey.ZC} (99%) rename src/System/DolDoc/{DocPutS.CC => DocPutS.ZC} (100%) rename src/System/DolDoc/{DocRecalc.CC => DocRecalc.ZC} (100%) rename src/System/DolDoc/{DocRecalcLib.CC => DocRecalcLib.ZC} (98%) rename src/System/DolDoc/{DocRun.CC => DocRun.ZC} (100%) rename src/System/DolDoc/{DocTerm.CC => DocTerm.ZC} (98%) rename src/System/DolDoc/{DocTree.CC => DocTree.ZC} (100%) rename src/System/DolDoc/{DocWidgetWiz.CC => DocWidgetWiz.ZC} (100%) rename src/System/DolDoc/{MakeDoc.CC => MakeDoc.ZC} (100%) rename src/System/{Externs.CC => Externs.ZC} (100%) rename src/System/God/{GodBible.CC => GodBible.ZC} (100%) rename src/System/God/{GodExterns.CC => GodExterns.ZC} (100%) rename src/System/God/{GodSong.CC => GodSong.ZC} (100%) rename src/System/God/{HolySpirit.CC => HolySpirit.ZC} (100%) rename src/System/God/{MakeGod.CC => MakeGod.ZC} (100%) rename src/System/Gr/{GrAsm.CC => GrAsm.ZC} (100%) rename src/System/Gr/{GrBitMap.CC => GrBitMap.ZC} (99%) rename src/System/Gr/{GrComposites.CC => GrComposites.ZC} (99%) rename src/System/Gr/{GrDC.CC => GrDC.ZC} (98%) rename src/System/Gr/{GrEnd.CC => GrEnd.ZC} (100%) rename src/System/Gr/{GrExterns.CC => GrExterns.ZC} (100%) rename src/System/Gr/{GrGlobals.CC => GrGlobals.ZC} (95%) rename src/System/Gr/{GrInitA.CC => GrInitA.ZC} (100%) rename src/System/Gr/{GrInitB.CC => GrInitB.ZC} (100%) rename src/System/Gr/{GrMath.CC => GrMath.ZC} (98%) rename src/System/Gr/{GrPalette.CC => GrPalette.ZC} (100%) rename src/System/Gr/{GrPrimatives.CC => GrPrimatives.ZC} (99%) rename src/System/Gr/{GrScreen.CC => GrScreen.ZC} (99%) rename src/System/Gr/{GrSpritePlot.CC => GrSpritePlot.ZC} (100%) rename src/System/Gr/{GrTextBase.CC => GrTextBase.ZC} (100%) rename src/System/Gr/{MakeGr.CC => MakeGr.ZC} (100%) rename src/System/Gr/{ScreenCast.CC => ScreenCast.ZC} (100%) rename src/System/Gr/{SpriteBitMap.CC => SpriteBitMap.ZC} (100%) rename src/System/Gr/{SpriteCode.CC => SpriteCode.ZC} (100%) rename src/System/Gr/{SpriteEd.CC => SpriteEd.ZC} (99%) rename src/System/Gr/{SpriteMain.CC => SpriteMain.ZC} (99%) rename src/System/Gr/{SpriteMesh.CC => SpriteMesh.ZC} (99%) rename src/System/Gr/{SpriteNew.CC => SpriteNew.ZC} (99%) rename src/System/Gr/{SpriteSideBar.CC => SpriteSideBar.ZC} (100%) rename src/System/{Hash.CC => Hash.ZC} (100%) rename src/System/{InFile.CC => InFile.ZC} (100%) rename src/System/{MakeSystem.CC => MakeSystem.ZC} (100%) rename src/System/{Math.CC => Math.ZC} (100%) rename src/System/{MathODE.CC => MathODE.ZC} (99%) rename src/System/{Memory.CC => Memory.ZC} (100%) rename src/System/{Menu.CC => Menu.ZC} (100%) rename src/System/{Mouse.CC => Mouse.ZC} (89%) rename src/System/{Registry.CC => Registry.ZC} (92%) rename src/System/{Sound.CC => Sound.ZC} (100%) rename src/System/{TaskSettings.CC => TaskSettings.ZC} (100%) rename src/System/{Training.CC => Training.ZC} (100%) rename src/System/Utils/{BinRep.CC => BinRep.ZC} (97%) rename src/System/Utils/{CPURep.CC => CPURep.ZC} (100%) rename src/System/Utils/{ConversionScript.CC => ConversionScript.ZC} (97%) rename src/System/Utils/{Diff.CC => Diff.ZC} (100%) rename src/System/Utils/{DocUtils.CC => DocUtils.ZC} (100%) rename src/System/Utils/{Find.CC => Find.ZC} (100%) rename src/System/Utils/{HeapLog.CC => HeapLog.ZC} (100%) rename src/System/Utils/{LineRep.CC => LineRep.ZC} (100%) rename src/System/Utils/{LinkCheck.CC => LinkCheck.ZC} (100%) rename src/System/Utils/{MakeUtils.CC => MakeUtils.ZC} (100%) rename src/System/Utils/{MemRep.CC => MemRep.ZC} (100%) rename src/System/Utils/{Merge.CC => Merge.ZC} (100%) rename src/System/Utils/{Profiler.CC => Profiler.ZC} (98%) rename src/System/Utils/{StrUtils.CC => StrUtils.ZC} (100%) rename src/System/Utils/{SysRep.CC => SysRep.ZC} (100%) rename src/System/Utils/{TaskRep.CC => TaskRep.ZC} (100%) rename src/System/Utils/{ToDolDoc.CC => ToDolDoc.ZC} (100%) rename src/System/Utils/{ToTXT.CC => ToTXT.ZC} (100%) rename src/System/Utils/{VideoRep.CC => VideoRep.ZC} (100%) rename src/System/{WallPaper.CC => WallPaper.ZC} (100%) rename src/System/{Win.CC => Win.ZC} (100%) rename src/System/{WinMgr.CC => WinMgr.ZC} (100%) rename src/System/{ZSplash.CC => ZSplash.ZC} (100%) diff --git a/build/AUTO.ISO b/build/AUTO.ISO index d71fbf0eb7000eb4f5354c64a425c6a1c8da312a..c63e9cada274dfb77f6e92c701fc7502cc848bde 100755 GIT binary patch delta 175334 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%0DX$Fdk% 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

s3M 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 CYPPfh delta 173606 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ΞDts(CQ8rCZ3$gLKP8Z=kI2r+OvuX@^yLVuqeCM? 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 diff --git a/build/build_iso.sh b/build/build_iso.sh index 56584a2e..87cc2489 100755 --- a/build/build_iso.sh +++ b/build/build_iso.sh @@ -16,8 +16,8 @@ sudo qemu-nbd -c dev/nbd0 -f raw ./ZealOS.raw sudo partprobe /dev/nbd0 echo "Merging with src/" sudo mount /dev/nbd0p1 /tmp/zealtmp -rm ../src/Home/Registry.CC # we use Registry for auto-iso process, don't want to overwrite -rm ../src/Home/MakeHome.CC # unneeded file +rm ../src/Home/Registry.ZC # we use Registry for auto-iso process, don't want to overwrite +rm ../src/Home/MakeHome.ZC # unneeded file sudo cp -r ../src/* /tmp/zealtmp/ sudo sync echo "Files copied, unmounting" diff --git a/src/Apps/Budget/BgtAccts.CC b/src/Apps/Budget/BgtAccts.ZC similarity index 100% rename from src/Apps/Budget/BgtAccts.CC rename to src/Apps/Budget/BgtAccts.ZC diff --git a/src/Apps/Budget/BgtEntry.CC b/src/Apps/Budget/BgtEntry.ZC similarity index 100% rename from src/Apps/Budget/BgtEntry.CC rename to src/Apps/Budget/BgtEntry.ZC diff --git a/src/Apps/Budget/BgtFile.CC b/src/Apps/Budget/BgtFile.ZC similarity index 100% rename from src/Apps/Budget/BgtFile.CC rename to src/Apps/Budget/BgtFile.ZC diff --git a/src/Apps/Budget/BgtMain.CC b/src/Apps/Budget/BgtMain.ZC similarity index 100% rename from src/Apps/Budget/BgtMain.CC rename to src/Apps/Budget/BgtMain.ZC diff --git a/src/Apps/Budget/BgtStrs.CC b/src/Apps/Budget/BgtStrs.ZC similarity index 100% rename from src/Apps/Budget/BgtStrs.CC rename to src/Apps/Budget/BgtStrs.ZC diff --git a/src/Apps/Budget/BgtTemplate.CC b/src/Apps/Budget/BgtTemplate.ZC similarity index 100% rename from src/Apps/Budget/BgtTemplate.CC rename to src/Apps/Budget/BgtTemplate.ZC diff --git a/src/Apps/Budget/Budget.CC b/src/Apps/Budget/Budget.ZC similarity index 100% rename from src/Apps/Budget/Budget.CC rename to src/Apps/Budget/Budget.ZC diff --git a/src/Apps/Budget/Install.CC b/src/Apps/Budget/Install.ZC similarity index 100% rename from src/Apps/Budget/Install.CC rename to src/Apps/Budget/Install.ZC diff --git a/src/Apps/Budget/Load.CC b/src/Apps/Budget/Load.ZC similarity index 100% rename from src/Apps/Budget/Load.CC rename to src/Apps/Budget/Load.ZC diff --git a/src/Apps/Budget/Run.CC b/src/Apps/Budget/Run.ZC similarity index 100% rename from src/Apps/Budget/Run.CC rename to src/Apps/Budget/Run.ZC diff --git a/src/Apps/GrModels/BallGen.CC b/src/Apps/GrModels/BallGen.ZC similarity index 96% rename from src/Apps/GrModels/BallGen.CC rename to src/Apps/GrModels/BallGen.ZC index 00bd53d6..b2d091ce 100755 --- a/src/Apps/GrModels/BallGen.CC +++ b/src/Apps/GrModels/BallGen.ZC @@ -62,7 +62,7 @@ I64 AddTri(BallDefineStruct *, I64 c, I64 n0, I64 n1, I64 n2) U8 *Ball2CSprite() { -//See $LK,"::/System/Gr/GrSpritePlot.CC",A="FL:::/System/Gr/GrSpritePlot.CC,1"$ for how CSprite are stored. +//See $LK,"::/System/Gr/GrSpritePlot.ZC",A="FL:::/System/Gr/GrSpritePlot.ZC,1"$ for how CSprite are stored. U8 *res = MAlloc(sizeof(CSpriteMeshU8s) + b->vertex_count * sizeof(CD3I32) + b->tri_count * sizeof(CMeshTri) + sprite_elem_base_sizes[SPT_END]), diff --git a/src/Apps/GrModels/Load.CC b/src/Apps/GrModels/Load.ZC similarity index 100% rename from src/Apps/GrModels/Load.CC rename to src/Apps/GrModels/Load.ZC diff --git a/src/Apps/GrModels/ManGen.CC b/src/Apps/GrModels/ManGen.ZC similarity index 98% rename from src/Apps/GrModels/ManGen.CC rename to src/Apps/GrModels/ManGen.ZC index 7103a638..23d24b8f 100755 --- a/src/Apps/GrModels/ManGen.CC +++ b/src/Apps/GrModels/ManGen.ZC @@ -187,7 +187,7 @@ U0 AddBox(ManDefineStruct *md, I64 c, U8 *Man2CSprite() { -//See $LK,"::/System/Gr/GrSpritePlot.CC",A="FL:::/System/Gr/GrSpritePlot.CC,1"$ for how CSprite are stored. +//See $LK,"::/System/Gr/GrSpritePlot.ZC",A="FL:::/System/Gr/GrSpritePlot.ZC,1"$ for how CSprite are stored. U8 *res = MAlloc(sizeof(CSpriteMeshU8s) + m->vertex_count * sizeof(CD3I32) + m->tri_count * sizeof(CMeshTri) + sprite_elem_base_sizes[SPT_END]), *dst = res; diff --git a/src/Apps/GrModels/Models.CC b/src/Apps/GrModels/Models.ZC similarity index 100% rename from src/Apps/GrModels/Models.CC rename to src/Apps/GrModels/Models.ZC diff --git a/src/Apps/GrModels/Run.CC b/src/Apps/GrModels/Run.ZC similarity index 100% rename from src/Apps/GrModels/Run.CC rename to src/Apps/GrModels/Run.ZC diff --git a/src/Apps/KeepAway/KeepAway.CC b/src/Apps/KeepAway/KeepAway.ZC similarity index 99% rename from src/Apps/KeepAway/KeepAway.CC rename to src/Apps/KeepAway/KeepAway.ZC index 60c55631..75d018a7 100755 --- a/src/Apps/KeepAway/KeepAway.CC +++ b/src/Apps/KeepAway/KeepAway.ZC @@ -1,5 +1,5 @@ //The ball and men were generated -//with $LK,"::/Apps/GrModels/Run.CC"$. +//with $LK,"::/Apps/GrModels/Run.ZC"$. //They were cut-and-pasted here. $BG,YELLOW$ diff --git a/src/Apps/KeepAway/Load.CC b/src/Apps/KeepAway/Load.ZC similarity index 100% rename from src/Apps/KeepAway/Load.CC rename to src/Apps/KeepAway/Load.ZC diff --git a/src/Apps/KeepAway/Run.CC b/src/Apps/KeepAway/Run.ZC similarity index 100% rename from src/Apps/KeepAway/Run.CC rename to src/Apps/KeepAway/Run.ZC diff --git a/src/Apps/Logic/Load.CC b/src/Apps/Logic/Load.ZC similarity index 100% rename from src/Apps/Logic/Load.CC rename to src/Apps/Logic/Load.ZC diff --git a/src/Apps/Logic/Logic.CC b/src/Apps/Logic/Logic.ZC similarity index 100% rename from src/Apps/Logic/Logic.CC rename to src/Apps/Logic/Logic.ZC diff --git a/src/Apps/Logic/Run.CC b/src/Apps/Logic/Run.ZC similarity index 100% rename from src/Apps/Logic/Run.CC rename to src/Apps/Logic/Run.ZC diff --git a/src/Apps/Psalmody/Examples/childish.CC b/src/Apps/Psalmody/Examples/childish.ZC similarity index 100% rename from src/Apps/Psalmody/Examples/childish.CC rename to src/Apps/Psalmody/Examples/childish.ZC diff --git a/src/Apps/Psalmody/Examples/night.CC b/src/Apps/Psalmody/Examples/night.ZC similarity index 100% rename from src/Apps/Psalmody/Examples/night.CC rename to src/Apps/Psalmody/Examples/night.ZC diff --git a/src/Apps/Psalmody/Examples/prosper.CC b/src/Apps/Psalmody/Examples/prosper.ZC similarity index 100% rename from src/Apps/Psalmody/Examples/prosper.CC rename to src/Apps/Psalmody/Examples/prosper.ZC diff --git a/src/Apps/Psalmody/Help.DD b/src/Apps/Psalmody/Help.DD index 7b8159b9..64edb959 100755 --- a/src/Apps/Psalmody/Help.DD +++ b/src/Apps/Psalmody/Help.DD @@ -4,10 +4,10 @@ $WW,1$$FG,5$$TX+CX,"Psalmody Help"$$FG$ * The clip can be used to cut and paste. -* $FG,2$Psalmody$FG$ uses $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ files as the song format! See $LK,"::/Apps/Psalmody/Examples/prosper.CC"$. The $FG,2$Psalmody$FG$ program does not fully parse the songs when loading them back in, so changes made outside $FG,2$Psalmody$FG$ will be lost, like if you add graphics. +* $FG,2$Psalmody$FG$ uses $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ files as the song format! See $LK,"::/Apps/Psalmody/Examples/prosper.ZC"$. The $FG,2$Psalmody$FG$ program does not fully parse the songs when loading them back in, so changes made outside $FG,2$Psalmody$FG$ will be lost, like if you add graphics. -* The first line of the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ song files is a comment with a category recognized by $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$(). The categories are $FG,2$"no nothing"$FG$, $FG,2$"has words"$FG$, $FG,2$"has graphics"$FG$, or $FG,2$"special"$FG$. The third character in the song comment is a digit rating number, shown in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$(). You can set the song rating in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$() by pressing $FG,2$0$FG$-$FG,2$9$FG$. You can request your reward from God by pressing $FG,2$r$FG$. You can press $FG,2$$FG$ to delete songs. +* The first line of the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ song files is a comment with a category recognized by $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$(). The categories are $FG,2$"no nothing"$FG$, $FG,2$"has words"$FG$, $FG,2$"has graphics"$FG$, or $FG,2$"special"$FG$. The third character in the song comment is a digit rating number, shown in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$(). You can set the song rating in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$() by pressing $FG,2$0$FG$-$FG,2$9$FG$. You can request your reward from God by pressing $FG,2$r$FG$. You can press $FG,2$$FG$ to delete songs. * You can take the $LK,"Play",A="MN:Play"$() statements out of a song file and place them in your programs. You can also add a song to a document with $FG,2$$FG$, but you should do it after pressing $FG,2$$FG$ because the clip-insert in $FG,2$$FG$ is screwy. See this $SO,"",A="4qG5EC4BeGG5qCeFD4sB5G4B5G4qG5EC4BeGG5qCeFD4sB5G4B5GqEeEFqE4BeG5FetC4A5GqFCEeEFqE4BeG5FetC4A5GqFC"$ after pressing $FG,2$$FG$, now. -* You can call $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$("~/Psalmody"); to play your songs. +* You can call $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$("~/Psalmody"); to play your songs. diff --git a/src/Apps/Psalmody/Install.CC b/src/Apps/Psalmody/Install.ZC similarity index 100% rename from src/Apps/Psalmody/Install.CC rename to src/Apps/Psalmody/Install.ZC diff --git a/src/Apps/Psalmody/JukeBox.CC b/src/Apps/Psalmody/JukeBox.ZC similarity index 99% rename from src/Apps/Psalmody/JukeBox.CC rename to src/Apps/Psalmody/JukeBox.ZC index c1bffdd2..f7182fd8 100755 --- a/src/Apps/Psalmody/JukeBox.CC +++ b/src/Apps/Psalmody/JukeBox.ZC @@ -134,7 +134,7 @@ public U0 JukeBox(U8 *dirname="~/Psalmody", U8 **_filename=NULL) try { dirname = StrNew(dirname); - st = MStrPrint("%s/*.CC", dirname); + st = MStrPrint("%s/*.ZC", dirname); tmpde = tmpde1 = FilesFind(st); Free(st); Free(dirname); diff --git a/src/Apps/Psalmody/JukePuppet.CC b/src/Apps/Psalmody/JukePuppet.ZC similarity index 100% rename from src/Apps/Psalmody/JukePuppet.CC rename to src/Apps/Psalmody/JukePuppet.ZC diff --git a/src/Apps/Psalmody/Load.CC b/src/Apps/Psalmody/Load.ZC similarity index 100% rename from src/Apps/Psalmody/Load.CC rename to src/Apps/Psalmody/Load.ZC diff --git a/src/Apps/Psalmody/Psalmody.CC b/src/Apps/Psalmody/Psalmody.ZC similarity index 100% rename from src/Apps/Psalmody/Psalmody.CC rename to src/Apps/Psalmody/Psalmody.ZC diff --git a/src/Apps/Psalmody/PsalmodyCtrls.CC b/src/Apps/Psalmody/PsalmodyCtrls.ZC similarity index 100% rename from src/Apps/Psalmody/PsalmodyCtrls.CC rename to src/Apps/Psalmody/PsalmodyCtrls.ZC diff --git a/src/Apps/Psalmody/PsalmodyDraw.CC b/src/Apps/Psalmody/PsalmodyDraw.ZC similarity index 100% rename from src/Apps/Psalmody/PsalmodyDraw.CC rename to src/Apps/Psalmody/PsalmodyDraw.ZC diff --git a/src/Apps/Psalmody/PsalmodyFile.CC b/src/Apps/Psalmody/PsalmodyFile.ZC similarity index 99% rename from src/Apps/Psalmody/PsalmodyFile.CC rename to src/Apps/Psalmody/PsalmodyFile.ZC index b8ba70b3..dd261504 100755 --- a/src/Apps/Psalmody/PsalmodyFile.CC +++ b/src/Apps/Psalmody/PsalmodyFile.ZC @@ -489,7 +489,7 @@ U8 *PsmSaveSong(U8 *dirname, U8 *full_filename) if (full_filename) Free(full_filename); else - StrPrint(doc->filename.name, "%s/Tmp.CC", dirname); + StrPrint(doc->filename.name, "%s/Tmp.ZC", dirname); DocWrite(doc, TRUE); full_filename = StrNew(doc->filename.name); DocDel(doc); diff --git a/src/Apps/Psalmody/PsalmodyMain.CC b/src/Apps/Psalmody/PsalmodyMain.ZC similarity index 100% rename from src/Apps/Psalmody/PsalmodyMain.CC rename to src/Apps/Psalmody/PsalmodyMain.ZC diff --git a/src/Apps/Psalmody/Run.CC b/src/Apps/Psalmody/Run.ZC similarity index 100% rename from src/Apps/Psalmody/Run.CC rename to src/Apps/Psalmody/Run.ZC diff --git a/src/Apps/Span/Install.CC b/src/Apps/Span/Install.ZC similarity index 100% rename from src/Apps/Span/Install.CC rename to src/Apps/Span/Install.ZC diff --git a/src/Apps/Span/Load.CC b/src/Apps/Span/Load.ZC similarity index 100% rename from src/Apps/Span/Load.CC rename to src/Apps/Span/Load.ZC diff --git a/src/Apps/Span/Run.CC b/src/Apps/Span/Run.ZC similarity index 100% rename from src/Apps/Span/Run.CC rename to src/Apps/Span/Run.ZC diff --git a/src/Apps/Span/SpanBridge.CC b/src/Apps/Span/SpanBridge.ZC similarity index 100% rename from src/Apps/Span/SpanBridge.CC rename to src/Apps/Span/SpanBridge.ZC diff --git a/src/Apps/Span/SpanDerive.CC b/src/Apps/Span/SpanDerive.ZC similarity index 100% rename from src/Apps/Span/SpanDerive.CC rename to src/Apps/Span/SpanDerive.ZC diff --git a/src/Apps/Span/SpanMain.CC b/src/Apps/Span/SpanMain.ZC similarity index 100% rename from src/Apps/Span/SpanMain.CC rename to src/Apps/Span/SpanMain.ZC diff --git a/src/Apps/Span/SpanNew.CC b/src/Apps/Span/SpanNew.ZC similarity index 100% rename from src/Apps/Span/SpanNew.CC rename to src/Apps/Span/SpanNew.ZC diff --git a/src/Apps/Strut/Load.CC b/src/Apps/Strut/Load.ZC similarity index 100% rename from src/Apps/Strut/Load.CC rename to src/Apps/Strut/Load.ZC diff --git a/src/Apps/Strut/Run.CC b/src/Apps/Strut/Run.ZC similarity index 100% rename from src/Apps/Strut/Run.CC rename to src/Apps/Strut/Run.ZC diff --git a/src/Apps/Strut/Strut.CC b/src/Apps/Strut/Strut.ZC similarity index 100% rename from src/Apps/Strut/Strut.CC rename to src/Apps/Strut/Strut.ZC diff --git a/src/Apps/TimeClock/Install.CC b/src/Apps/TimeClock/Install.ZC similarity index 100% rename from src/Apps/TimeClock/Install.CC rename to src/Apps/TimeClock/Install.ZC diff --git a/src/Apps/TimeClock/Load.CC b/src/Apps/TimeClock/Load.ZC similarity index 100% rename from src/Apps/TimeClock/Load.CC rename to src/Apps/TimeClock/Load.ZC diff --git a/src/Apps/TimeClock/TimeClk.CC b/src/Apps/TimeClock/TimeClk.ZC similarity index 100% rename from src/Apps/TimeClock/TimeClk.CC rename to src/Apps/TimeClock/TimeClk.ZC diff --git a/src/Apps/Titanium/Load.CC b/src/Apps/Titanium/Load.ZC similarity index 100% rename from src/Apps/Titanium/Load.CC rename to src/Apps/Titanium/Load.ZC diff --git a/src/Apps/Titanium/Run.CC b/src/Apps/Titanium/Run.ZC similarity index 100% rename from src/Apps/Titanium/Run.CC rename to src/Apps/Titanium/Run.ZC diff --git a/src/Apps/Titanium/Titanium.CC b/src/Apps/Titanium/Titanium.ZC similarity index 100% rename from src/Apps/Titanium/Titanium.CC rename to src/Apps/Titanium/Titanium.ZC diff --git a/src/Apps/ToTheFront/AIs/Human.CC b/src/Apps/ToTheFront/AIs/Human.ZC similarity index 100% rename from src/Apps/ToTheFront/AIs/Human.CC rename to src/Apps/ToTheFront/AIs/Human.ZC diff --git a/src/Apps/ToTheFront/AIs/SimpleAI.CC b/src/Apps/ToTheFront/AIs/SimpleAI.ZC similarity index 100% rename from src/Apps/ToTheFront/AIs/SimpleAI.CC rename to src/Apps/ToTheFront/AIs/SimpleAI.ZC diff --git a/src/Apps/ToTheFront/Install.CC b/src/Apps/ToTheFront/Install.ZC similarity index 100% rename from src/Apps/ToTheFront/Install.CC rename to src/Apps/ToTheFront/Install.ZC diff --git a/src/Apps/ToTheFront/Load.CC b/src/Apps/ToTheFront/Load.ZC similarity index 100% rename from src/Apps/ToTheFront/Load.CC rename to src/Apps/ToTheFront/Load.ZC diff --git a/src/Apps/ToTheFront/Run.CC b/src/Apps/ToTheFront/Run.ZC similarity index 100% rename from src/Apps/ToTheFront/Run.CC rename to src/Apps/ToTheFront/Run.ZC diff --git a/src/Apps/ToTheFront/TTFDraw.CC b/src/Apps/ToTheFront/TTFDraw.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFDraw.CC rename to src/Apps/ToTheFront/TTFDraw.ZC diff --git a/src/Apps/ToTheFront/TTFFire.CC b/src/Apps/ToTheFront/TTFFire.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFFire.CC rename to src/Apps/ToTheFront/TTFFire.ZC diff --git a/src/Apps/ToTheFront/TTFGlobals.CC b/src/Apps/ToTheFront/TTFGlobals.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFGlobals.CC rename to src/Apps/ToTheFront/TTFGlobals.ZC diff --git a/src/Apps/ToTheFront/TTFInit.CC b/src/Apps/ToTheFront/TTFInit.ZC similarity index 99% rename from src/Apps/ToTheFront/TTFInit.CC rename to src/Apps/ToTheFront/TTFInit.ZC index 02a87126..2707d521 100755 --- a/src/Apps/ToTheFront/TTFInit.CC +++ b/src/Apps/ToTheFront/TTFInit.ZC @@ -440,10 +440,10 @@ U0 PlayerPick(U8 *dirname, I64 player) CDoc *doc = DocNew; Bool *old_silent = Silent; - st = MStrPrint("%s/*.CC*", dirname); + st = MStrPrint("%s/*.ZC*", dirname); tmpde = FilesFind(st); Free(st); - tmpde2 = FilesFind("~/ToTheFront/*.CC*"); + tmpde2 = FilesFind("~/ToTheFront/*.ZC*"); tmpde1 = tmpde; Silent(old_silent); diff --git a/src/Apps/ToTheFront/TTFLib.CC b/src/Apps/ToTheFront/TTFLib.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFLib.CC rename to src/Apps/ToTheFront/TTFLib.ZC diff --git a/src/Apps/ToTheFront/TTFMove.CC b/src/Apps/ToTheFront/TTFMove.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFMove.CC rename to src/Apps/ToTheFront/TTFMove.ZC diff --git a/src/Apps/ToTheFront/TTFVis.CC b/src/Apps/ToTheFront/TTFVis.ZC similarity index 100% rename from src/Apps/ToTheFront/TTFVis.CC rename to src/Apps/ToTheFront/TTFVis.ZC diff --git a/src/Apps/ToTheFront/ToTheFront.CC b/src/Apps/ToTheFront/ToTheFront.ZC similarity index 100% rename from src/Apps/ToTheFront/ToTheFront.CC rename to src/Apps/ToTheFront/ToTheFront.ZC diff --git a/src/Apps/Vocabulary/Load.CC b/src/Apps/Vocabulary/Load.ZC similarity index 100% rename from src/Apps/Vocabulary/Load.CC rename to src/Apps/Vocabulary/Load.ZC diff --git a/src/Apps/Vocabulary/Run.CC b/src/Apps/Vocabulary/Run.ZC similarity index 100% rename from src/Apps/Vocabulary/Run.CC rename to src/Apps/Vocabulary/Run.ZC diff --git a/src/Apps/Vocabulary/VocabQuiz.CC b/src/Apps/Vocabulary/VocabQuiz.ZC similarity index 100% rename from src/Apps/Vocabulary/VocabQuiz.CC rename to src/Apps/Vocabulary/VocabQuiz.ZC diff --git a/src/Apps/X-Caliber/Load.CC b/src/Apps/X-Caliber/Load.ZC similarity index 100% rename from src/Apps/X-Caliber/Load.CC rename to src/Apps/X-Caliber/Load.ZC diff --git a/src/Apps/X-Caliber/Run.CC b/src/Apps/X-Caliber/Run.ZC similarity index 100% rename from src/Apps/X-Caliber/Run.CC rename to src/Apps/X-Caliber/Run.ZC diff --git a/src/Apps/X-Caliber/X-Caliber.CC b/src/Apps/X-Caliber/X-Caliber.ZC similarity index 100% rename from src/Apps/X-Caliber/X-Caliber.CC rename to src/Apps/X-Caliber/X-Caliber.ZC diff --git a/src/Apps/X-Caliber/XCCtrls.CC b/src/Apps/X-Caliber/XCCtrls.ZC similarity index 100% rename from src/Apps/X-Caliber/XCCtrls.CC rename to src/Apps/X-Caliber/XCCtrls.ZC diff --git a/src/Compiler/Asm.CC b/src/Compiler/Asm.ZC similarity index 100% rename from src/Compiler/Asm.CC rename to src/Compiler/Asm.ZC diff --git a/src/Compiler/AsmInit.CC b/src/Compiler/AsmInit.ZC similarity index 100% rename from src/Compiler/AsmInit.CC rename to src/Compiler/AsmInit.ZC diff --git a/src/Compiler/AsmLib.CC b/src/Compiler/AsmLib.ZC similarity index 100% rename from src/Compiler/AsmLib.CC rename to src/Compiler/AsmLib.ZC diff --git a/src/Compiler/AsmResolve.CC b/src/Compiler/AsmResolve.ZC similarity index 100% rename from src/Compiler/AsmResolve.CC rename to src/Compiler/AsmResolve.ZC diff --git a/src/Compiler/BackA.CC b/src/Compiler/BackA.ZC similarity index 100% rename from src/Compiler/BackA.CC rename to src/Compiler/BackA.ZC diff --git a/src/Compiler/BackB.CC b/src/Compiler/BackB.ZC similarity index 100% rename from src/Compiler/BackB.CC rename to src/Compiler/BackB.ZC diff --git a/src/Compiler/BackC.CC b/src/Compiler/BackC.ZC similarity index 100% rename from src/Compiler/BackC.CC rename to src/Compiler/BackC.ZC diff --git a/src/Compiler/BackFA.CC b/src/Compiler/BackFA.ZC similarity index 100% rename from src/Compiler/BackFA.CC rename to src/Compiler/BackFA.ZC diff --git a/src/Compiler/BackFB.CC b/src/Compiler/BackFB.ZC similarity index 100% rename from src/Compiler/BackFB.CC rename to src/Compiler/BackFB.ZC diff --git a/src/Compiler/BackLib.CC b/src/Compiler/BackLib.ZC similarity index 100% rename from src/Compiler/BackLib.CC rename to src/Compiler/BackLib.ZC diff --git a/src/Compiler/CExcept.CC b/src/Compiler/CExcept.ZC similarity index 100% rename from src/Compiler/CExcept.CC rename to src/Compiler/CExcept.ZC diff --git a/src/Compiler/CExterns.CC b/src/Compiler/CExterns.ZC similarity index 100% rename from src/Compiler/CExterns.CC rename to src/Compiler/CExterns.ZC diff --git a/src/Compiler/CHash.CC b/src/Compiler/CHash.ZC similarity index 100% rename from src/Compiler/CHash.CC rename to src/Compiler/CHash.ZC diff --git a/src/Compiler/CInit.CC b/src/Compiler/CInit.ZC similarity index 100% rename from src/Compiler/CInit.CC rename to src/Compiler/CInit.ZC diff --git a/src/Compiler/CMain.CC b/src/Compiler/CMain.ZC similarity index 99% rename from src/Compiler/CMain.CC rename to src/Compiler/CMain.ZC index 9d50d858..ad8aa8cf 100755 --- a/src/Compiler/CMain.CC +++ b/src/Compiler/CMain.ZC @@ -711,7 +711,7 @@ I64 ExePrint(U8 *format, ...) I64 ExeFile(U8 *name, I64 ccf_flags=0) {//JIT Compile and execute a file. I64 res; - U8 *name2 = ExtDefault(name, "CC"), *st = MStrPrint("#include \"%s\";", name2); + U8 *name2 = ExtDefault(name, "ZC"), *st = MStrPrint("#include \"%s\";", name2); res = ExePutS(st, name, ccf_flags); Free(st); @@ -760,7 +760,7 @@ I64 ExePrint2(U8 *format, ...) I64 ExeFile2(U8 *name, I64 ccf_flags=0) {//throws exceptions I64 res; - U8 *name2 = ExtDefault(name, "CC"), *st = MStrPrint("#include \"%s\";", name2); + U8 *name2 = ExtDefault(name, "ZC"), *st = MStrPrint("#include \"%s\";", name2); res = ExePutS2(st, name, ccf_flags); Free(st); diff --git a/src/Compiler/CMisc.CC b/src/Compiler/CMisc.ZC similarity index 100% rename from src/Compiler/CMisc.CC rename to src/Compiler/CMisc.ZC diff --git a/src/Compiler/Lex.CC b/src/Compiler/Lex.ZC similarity index 99% rename from src/Compiler/Lex.CC rename to src/Compiler/Lex.ZC index d8812233..3756ada7 100755 --- a/src/Compiler/Lex.CC +++ b/src/Compiler/Lex.ZC @@ -34,7 +34,7 @@ CCompCtrl *CompCtrlNew(U8 *buf=NULL, I64 flags=0, U8 *filename=NULL) {//MAlloc and Init CCompCtrl. //Frees buf in $LK,"CompCtrlDel",A="MN:CompCtrlDel"$ unless $LK,"CCF_DONT_FREE_BUF",A="MN:CCF_DONT_FREE_BUF"$ flag is set. //FileName is for error reporting. If files are #included, - //new names are used. See $LK,"Psalmody CompCtrlNew",A="FF:::/Apps/Psalmody/PsalmodyFile.CC,CompCtrlNew"$. + //new names are used. See $LK,"Psalmody CompCtrlNew",A="FF:::/Apps/Psalmody/PsalmodyFile.ZC,CompCtrlNew"$. CCompCtrl *cc = CAlloc(sizeof(CCompCtrl)); CLexFile *tmpf; @@ -842,7 +842,7 @@ lex_float_start: case KW_INCLUDE: if (Lex(cc) != TK_STR) goto lex_end; - fbuf = ExtDefault(cc->cur_str, "CC"); + fbuf = ExtDefault(cc->cur_str, "ZC"); buf2 = FileNameAbs(fbuf); Free(fbuf); if (Bt(&sys_run_level, RLf_DOC)) diff --git a/src/Compiler/LexLib.CC b/src/Compiler/LexLib.ZC similarity index 99% rename from src/Compiler/LexLib.CC rename to src/Compiler/LexLib.ZC index 48114ab8..84e4bbb9 100755 --- a/src/Compiler/LexLib.CC +++ b/src/Compiler/LexLib.ZC @@ -48,7 +48,7 @@ U0 LexPopNoRestore(CCompCtrl *cc) } I64 MemberMetaData(U8 *needle_str, CMemberList *haystack_member_list) -{//Find meta data name, return meta data value. See $LK,"::/Demo/ClassMeta.CC"$. +{//Find meta data name, return meta data value. See $LK,"::/Demo/ClassMeta.ZC"$. CMemberListMeta *meta = haystack_member_list->meta; while (meta) @@ -62,7 +62,7 @@ I64 MemberMetaData(U8 *needle_str, CMemberList *haystack_member_list) } CMemberListMeta *MemberMetaFind(U8 *needle_str, CMemberList *haystack_member_list) -{//Find meta data name, return meta data struct. See $LK,"::/Demo/ClassMeta.CC"$. +{//Find meta data name, return meta data struct. See $LK,"::/Demo/ClassMeta.ZC"$. CMemberListMeta *meta = haystack_member_list->meta; while (meta) diff --git a/src/Compiler/OptLib.CC b/src/Compiler/OptLib.ZC similarity index 100% rename from src/Compiler/OptLib.CC rename to src/Compiler/OptLib.ZC diff --git a/src/Compiler/OptPass012.CC b/src/Compiler/OptPass012.ZC similarity index 99% rename from src/Compiler/OptPass012.CC rename to src/Compiler/OptPass012.ZC index 3a89375c..6ec621d4 100755 --- a/src/Compiler/OptPass012.CC +++ b/src/Compiler/OptPass012.ZC @@ -3,7 +3,7 @@ Pass #0 When parsing the arg expressions to a function call, there is a call to OptPass012 to determine -the type of the expression. $LK,"OptPass012",A="FF:::/Compiler/ParseExp.CC,OptPass012"$ +the type of the expression. $LK,"OptPass012",A="FF:::/Compiler/ParseExp.ZC,OptPass012"$ Pass #1 & #2 Constant expressions are simplified. diff --git a/src/Compiler/OptPass3.CC b/src/Compiler/OptPass3.ZC similarity index 100% rename from src/Compiler/OptPass3.CC rename to src/Compiler/OptPass3.ZC diff --git a/src/Compiler/OptPass4.CC b/src/Compiler/OptPass4.ZC similarity index 99% rename from src/Compiler/OptPass4.CC rename to src/Compiler/OptPass4.ZC index 0befdc5f..462d0c4f 100755 --- a/src/Compiler/OptPass4.CC +++ b/src/Compiler/OptPass4.ZC @@ -410,7 +410,7 @@ p4_sib: case IC_ASSIGN_PP: case IC_ASSIGN_MM: //this value was stashed during pass012 for pointer arithmetic - tmpi->ic_class2 = tmpi->t.class2; //See $LK,"ic_class2",A="FF:::/Compiler/BackB.CC,ic_class2"$ + tmpi->ic_class2 = tmpi->t.class2; //See $LK,"ic_class2",A="FF:::/Compiler/BackB.ZC,ic_class2"$ case IC_ASSIGN: case IC_SHL_EQU: case IC_SHR_EQU: diff --git a/src/Compiler/OptPass5.CC b/src/Compiler/OptPass5.ZC similarity index 100% rename from src/Compiler/OptPass5.CC rename to src/Compiler/OptPass5.ZC diff --git a/src/Compiler/OptPass6.CC b/src/Compiler/OptPass6.ZC similarity index 100% rename from src/Compiler/OptPass6.CC rename to src/Compiler/OptPass6.ZC diff --git a/src/Compiler/OptPass789A.CC b/src/Compiler/OptPass789A.ZC similarity index 100% rename from src/Compiler/OptPass789A.CC rename to src/Compiler/OptPass789A.ZC diff --git a/src/Compiler/ParseExp.CC b/src/Compiler/ParseExp.ZC similarity index 100% rename from src/Compiler/ParseExp.CC rename to src/Compiler/ParseExp.ZC diff --git a/src/Compiler/ParseLib.CC b/src/Compiler/ParseLib.ZC similarity index 100% rename from src/Compiler/ParseLib.CC rename to src/Compiler/ParseLib.ZC diff --git a/src/Compiler/ParseStatement.CC b/src/Compiler/ParseStatement.ZC similarity index 100% rename from src/Compiler/ParseStatement.CC rename to src/Compiler/ParseStatement.ZC diff --git a/src/Compiler/ParseVar.CC b/src/Compiler/ParseVar.ZC similarity index 100% rename from src/Compiler/ParseVar.CC rename to src/Compiler/ParseVar.ZC diff --git a/src/Compiler/Templates.CC b/src/Compiler/Templates.ZC similarity index 100% rename from src/Compiler/Templates.CC rename to src/Compiler/Templates.ZC diff --git a/src/Compiler/UAsm.CC b/src/Compiler/UAsm.ZC similarity index 100% rename from src/Compiler/UAsm.CC rename to src/Compiler/UAsm.ZC diff --git a/src/Demo/AcctExample/HomeKeyPlugIns.CC b/src/Demo/AcctExample/HomeKeyPlugIns.ZC similarity index 100% rename from src/Demo/AcctExample/HomeKeyPlugIns.CC rename to src/Demo/AcctExample/HomeKeyPlugIns.ZC diff --git a/src/Demo/AcctExample/HomeLocalize.CC b/src/Demo/AcctExample/HomeLocalize.ZC similarity index 100% rename from src/Demo/AcctExample/HomeLocalize.CC rename to src/Demo/AcctExample/HomeLocalize.ZC diff --git a/src/Demo/AcctExample/HomeSys.CC b/src/Demo/AcctExample/HomeSys.ZC similarity index 100% rename from src/Demo/AcctExample/HomeSys.CC rename to src/Demo/AcctExample/HomeSys.ZC diff --git a/src/Demo/AcctExample/HomeWrappers.CC b/src/Demo/AcctExample/HomeWrappers.ZC similarity index 100% rename from src/Demo/AcctExample/HomeWrappers.CC rename to src/Demo/AcctExample/HomeWrappers.ZC diff --git a/src/Demo/AcctExample/MakeHome.CC b/src/Demo/AcctExample/MakeHome.ZC similarity index 100% rename from src/Demo/AcctExample/MakeHome.CC rename to src/Demo/AcctExample/MakeHome.ZC diff --git a/src/Demo/AcctExample/Once.CC b/src/Demo/AcctExample/Once.ZC similarity index 87% rename from src/Demo/AcctExample/Once.CC rename to src/Demo/AcctExample/Once.ZC index 44801c72..31fcfa33 100755 --- a/src/Demo/AcctExample/Once.CC +++ b/src/Demo/AcctExample/Once.ZC @@ -3,7 +3,7 @@ //This file is executed by the //first terminal window upon start-up. -//See $LK,"Once",A="FF:/Home/HomeSys.CC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. +//See $LK,"Once",A="FF:/Home/HomeSys.ZC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. // Type("::/Doc/Customize.DD"); @@ -21,8 +21,8 @@ U0 Tmp() DocBottom; if (RunFile("::/Misc/OSInstall",, FALSE)) { - Del("C:/Home/DoDistro.CC"); - Del("D:/Home/DoDistro.CC"); + Del("C:/Home/DoDistro.ZC"); + Del("D:/Home/DoDistro.ZC"); OnceDrive('C', "\"\n\nRun TOSStaffIns;\n\n\n\";"); OnceDrive('D', ""); //This command uses cached Registry file. if (PressAKey != CH_SHIFT_ESC) diff --git a/src/Demo/AcctExample/PersonalMenu.DD b/src/Demo/AcctExample/PersonalMenu.DD index bcc4cdfdcbb071313eb8c2b57b0562cff2139510..0758078fee41d8a133898f7b3af4097e561f25dc 100755 GIT binary patch delta 16 XcmccE&T_GxWrLeAW7KAM;jRw=IY$Ph delta 16 XcmccE&T_GxWrLeAqw{8W;jRw=IK2jq diff --git a/src/Demo/AcctExample/PersonalNotes.DD b/src/Demo/AcctExample/PersonalNotes.DD index b24d106f..00c189c8 100755 --- a/src/Demo/AcctExample/PersonalNotes.DD +++ b/src/Demo/AcctExample/PersonalNotes.DD @@ -24,11 +24,11 @@ $WW,1$$FG,5$$TX+CX,"TODO"$$FG$ * 170624 $LK,"DiskCheck",A="MN:DiskCheck"$() showed extra alloced clus for FAT32, Sup1Hymns. ClusNum was '.'+1 and clus was zero. -* $LK,"::/Apps/X-Caliber/X-Caliber.CC"$ +* $LK,"::/Apps/X-Caliber/X-Caliber.ZC"$ * Add asteroid harbor defense. * Afterburner thruster. -* $LK,"::/Apps/Titanium/Titanium.CC"$ +* $LK,"::/Apps/Titanium/Titanium.ZC"$ * Lead-in at start of game with no enemy. * Have highway of death. * Fix straight shooting. @@ -37,18 +37,18 @@ $WW,1$$FG,5$$TX+CX,"TODO"$$FG$ * $MA-X+PU,"64-Bit Device Memory",LM="F(\"mem64_ptr\");View;"$ is not implemented. -* Investigate why packet loss $LK,"Training Sleep(1)",A="FF:::/System/Training.CC,Sleep(1)"$. +* Investigate why packet loss $LK,"Training Sleep(1)",A="FF:::/System/Training.ZC,Sleep(1)"$. * Add AVL or red/black binary tree library support. We have fixed-size stack. Auto-balancing binary tree is very needed. I've done everything myself. I don't want to ruin a perfect record. I'm in no hurry. -* $LK,"SpriteEd",A="FI:::/System/Gr/SpriteEd.CC"$ shift pts, Ctrl pt for ellipse/polygon w,h is off when rotated. +* $LK,"SpriteEd",A="FI:::/System/Gr/SpriteEd.ZC"$ shift pts, Ctrl pt for ellipse/polygon w,h is off when rotated. -* God said this is bad. $LK,"FL:::/System/DolDoc/DocFind.CC,41"$ +* God said this is bad. $LK,"FL:::/System/DolDoc/DocFind.ZC,41"$ * Backward is broken? * $LK,"Find",A="MN:Find"$() search sprite text? -* Cannot include ':' in $LK,"Document Links",A="FF:::/System/DolDoc/DocLink.CC,AD"$ search string. +* Cannot include ':' in $LK,"Document Links",A="FF:::/System/DolDoc/DocLink.ZC,AD"$ search string. * $$DA fixed width string: or permanently shortens. * 11/19/16 editor took long time after copying old testament onto clip and exiting. @@ -61,9 +61,9 @@ $WW,1$$FG,5$$TX+CX,"TODO"$$FG$ * $LK,"DOCT_HEX_ED",A="MN:DOCT_HEX_ED"$ with odd size, ASCII cannot be edited. -* $LK,"FL:::/System/Gr/SpriteEd.CC,789"$ Resize bitmap? +* $LK,"FL:::/System/Gr/SpriteEd.ZC,789"$ Resize bitmap? -* $LK,"DOCEF_REMALLOC_DATA",A="FF:::/System/DolDoc/DocChar.CC,DOCEF_REMALLOC_DATA"$ HexEdit Remalloc. +* $LK,"DOCEF_REMALLOC_DATA",A="FF:::/System/DolDoc/DocChar.ZC,DOCEF_REMALLOC_DATA"$ HexEdit Remalloc. * $LK,"DOCF_DBL_DOLLARS",A="MN:DOCF_DBL_DOLLARS"$ in $LK,"Reindention",A="MN:EdCodeTools2"$. @@ -87,7 +87,7 @@ $WW,1$$FG,5$$TX+CX,"TODO"$$FG$ * Bible ranges in $LK,"BibleVerse",A="MN:BibleVerse"$(). -* $LK,"::/Demo/Games/FlatTops.CC"$ is torpedo, not bombs. +* $LK,"::/Demo/Games/FlatTops.ZC"$ is torpedo, not bombs. * Reset MPs with $LK,"Core0StartMP",A="MN:Core0StartMP"$() after boot. Free old task memory? @@ -104,13 +104,13 @@ $WW,1$$FG,5$$TX+CX,"TODO"$$FG$ * Get rid of JIFFY and HPET and just use tS. -* Use "Rosetta Stone" in documentaion pointing to this: $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +* Use "Rosetta Stone" in documentaion pointing to this: $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. * Change %h*c so the character is not a arg? * $LK,"GrLineFat3",A="MN:GrLineFat3"$() needs a little work. -* $LK,"GrFillTri0",A="MN:GrFillTri0"$() with both $LK,"GrHLine",A="MN:GrHLine"$() and $LK,"GrVLine",A="MN:GrVLine"$() don't match in $LK,"::/Demo/Games/CastleFrankenstein.CC"$ causing wall spot pixels. +* $LK,"GrFillTri0",A="MN:GrFillTri0"$() with both $LK,"GrHLine",A="MN:GrHLine"$() and $LK,"GrVLine",A="MN:GrVLine"$() don't match in $LK,"::/Demo/Games/CastleFrankenstein.ZC"$ causing wall spot pixels. $FG,5$$TX+CX,"TODO? Meh"$$FG$ @@ -122,13 +122,13 @@ $FG,5$$TX+CX,"TODO? Meh"$$FG$ * $LK,"Mem32DevAlloc",A="MN:Mem32DevAlloc"$() is broken. Devices should be in free spot of E820 report. -* $LK,"SpriteEd",A="FI:::/System/Gr/SpriteEd.CC"$: Strip $LK,"SPT_SHIFT",A="MN:SPT_SHIFT"$ origin cmds? +* $LK,"SpriteEd",A="FI:::/System/Gr/SpriteEd.ZC"$: Strip $LK,"SPT_SHIFT",A="MN:SPT_SHIFT"$ origin cmds? * Clean-up ASCII #127 delete char? (No. Maybe, we want a new usage for 127 in future centuries.) * Compiler: Exceptions don't free $LK,"CCompCtrl",A="MN:CCompCtrl"$ stuff. -* $LK,"::/System/DolDoc/DocHighlight.CC"$ for code comments at top of documents. +* $LK,"::/System/DolDoc/DocHighlight.ZC"$ for code comments at top of documents. * Unhandled exception messages from MP's get overwritten by WinMgr. @@ -145,7 +145,7 @@ $FG,5$$TX+CX,"TODO? Meh"$$FG$ $FG,5$$TX+CX,"TODO: Too Hard, or Not Worth Doing."$$FG$ * AutoComplete/$LK,"Man",A="MN:Man"$() Jmp for user code. -* $LK,"Bible sized nodes",A="FF:::/System/DolDoc/DocRecalc.CC,->tag + i"$ +* $LK,"Bible sized nodes",A="FF:::/System/DolDoc/DocRecalc.ZC,->tag + i"$ * $LK,"FileMgr",A="MN:FileMgr"$() is bad with lots of files. @@ -153,7 +153,7 @@ $FG,5$$TX+CX,"TODO: Too Hard, or Not Worth Doing."$$FG$ * Log-to-file is inefficient because we load and save whole file. -* $LK,"ICMov",A="MN:ICMov"$() $LK,"PUSH_CMP",A="FF:::/Compiler/BackLib.CC,PUSH_CMP"$ and $LK,"MDf_STACK",A="MN:MDf_STACK"$? Perhaps, it's okay. +* $LK,"ICMov",A="MN:ICMov"$() $LK,"PUSH_CMP",A="FF:::/Compiler/BackLib.ZC,PUSH_CMP"$ and $LK,"MDf_STACK",A="MN:MDf_STACK"$? Perhaps, it's okay. * Short FAT32 ~ names. @@ -169,17 +169,17 @@ $ID,5$$HL,1$U0 Main() U0 (*fp_old_draw_mouse)(CDC *dc,I64 x,I64 y)=gr.fp_draw_mouse; } $ID,-5$$HL,0$ -* Compiler: Get rid of $LK,"0x20000",A="FF:::/Compiler/CMain.CC,0x20000"$ limit. +* Compiler: Get rid of $LK,"0x20000",A="FF:::/Compiler/CMain.ZC,0x20000"$ limit. -* $LK,"GrFloodFillRay",A="MN:GrFloodFillRay"$: Get rid of $LK,"0x80000",A="FF:::/System/Gr/GrPrimatives.CC,0x80000"$ limit. +* $LK,"GrFloodFillRay",A="MN:GrFloodFillRay"$: Get rid of $LK,"0x80000",A="FF:::/System/Gr/GrPrimatives.ZC,0x80000"$ limit. $FG,5$$TX+CX,"Bugs"$$FG$ -* 1/28/16 $LK,"::/Demo/Graphics/Pick3D.CC"$ crashed in TestSuite. +* 1/28/16 $LK,"::/Demo/Graphics/Pick3D.ZC"$ crashed in TestSuite. * 1/12/16 make RAM drive 2288 blks, $FG,2$CopyTree("C:/Home","B:/Home"); $FG$ Disk runs-out of space and hangs instead of reporting errors. -* Bug introduced around 11/1/15. Changed $LK,"::/Kernel/Sched.CC"$ and now $LK,"WinToTop",A="MN:WinToTop"$ is called on System task at start-up, sometimes. Might be user's fault because of bad keys pressed during VMware power-on init. Might be fixed by $LK,"ACf_INIT_IN_PROGRESS",A="MN:ACf_INIT_IN_PROGRESS"$. +* Bug introduced around 11/1/15. Changed $LK,"::/Kernel/Sched.ZC"$ and now $LK,"WinToTop",A="MN:WinToTop"$ is called on System task at start-up, sometimes. Might be user's fault because of bad keys pressed during VMware power-on init. Might be fixed by $LK,"ACf_INIT_IN_PROGRESS",A="MN:ACf_INIT_IN_PROGRESS"$. * 1/12/16 $LK,"ATARepEntry",A="MN:ATARepEntry"$ shows corrupted bttns. Weird. Perhaps, my imagination. @@ -188,7 +188,7 @@ $FG,5$$TX+CX,"3rd Party Bugs"$$FG$ * VMware: Stretch to full screen * VMware: PC speaker sound distorted. * VMware: 8/2/2015 start-up. Probably multicore. -* VMware: $LK,"CtrlAltDel",A="FF:::/Kernel/SerialDev/Keyboard.CC,CtrlAltDel"$ on +* VMware: $LK,"CtrlAltDel",A="FF:::/Kernel/SerialDev/Keyboard.ZC,CtrlAltDel"$ on * VMware: Size zero files don't copy out of mounted disk? (Might be fixed.) @@ -206,7 +206,7 @@ $FG,5$$TX+CX,"Bugs? Not really sure."$$FG$ * 1/?/2015,8/10/2015 Macro sel in Menu did not go to shell? No, I think just twice. Not a bug. * 5/7/14:Something like $LK,"InSetMouse",A="MN:InSetMouse"$ caused hang, then reboot in TestSuite. -* 5/7/14:#63 Maybe, $LK,"::/Demo/Graphics/Pick3D.CC"$ crashed in TestSuite. +* 5/7/14:#63 Maybe, $LK,"::/Demo/Graphics/Pick3D.ZC"$ crashed in TestSuite. * $LK,"StrPrintJoin",A="MN:StrPrintJoin"$(,st); With st="\n\\"; (Forgot what this is talking about.) @@ -230,9 +230,9 @@ $ID,-5$ * $LK,"U",A="MN:U"$() negative byte displacement, neg 32-bit disp. -* Race condition in $LK,"::/Demo/Games/FlatTops.CC"$ torpedo. +* Race condition in $LK,"::/Demo/Games/FlatTops.ZC"$ torpedo. -* Links to self document if empty file name? $LK,"Document Links",A="FF:::/System/DolDoc/DocLink.CC,AD"$ +* Links to self document if empty file name? $LK,"Document Links",A="FF:::/System/DolDoc/DocLink.ZC,AD"$ * $LK,"FUF_RECURSE",A="MN:FUF_RECURSE"$ would be nice if capital "+R". @@ -259,7 +259,7 @@ $FG,5$$TX+CX,"Committee Needed"$$FG$ * Make so just CdRom; command to copy entire disk to ::/CdRom directory? -* $LK,"MP DepthBuf",A="FF:::/System/Gr/SpriteMesh.CC,//We"$ is a kludge because of dc->depth_buf=NULL in various graphics routines. +* $LK,"MP DepthBuf",A="FF:::/System/Gr/SpriteMesh.ZC,//We"$ is a kludge because of dc->depth_buf=NULL in various graphics routines. * Improve editor undo, add redo. @@ -276,8 +276,8 @@ $FG,5$$TX+CX,"Committee Needed"$$FG$ * $LK,"GrPutChar3",A="MN:GrPutChar3"$() with depth buf? -* Eliminate? $LK,"::/System/Ctrls/CtrlsA.CC"$? -* Eliminate? $LK,"::/System/MathODE.CC"$? +* Eliminate? $LK,"::/System/Ctrls/CtrlsA.ZC"$? +* Eliminate? $LK,"::/System/MathODE.ZC"$? * Eliminate? $LK,"Complex",A="MN:Complex"$? * Eliminate? $LK,"CDC",A="MN:CDC"$.brush? * Eliminate? $LK,"Mat4x4MulXYZ",A="MN:Mat4x4MulXYZ"$() change to 3x3? @@ -287,7 +287,7 @@ $FG,5$$TX+CX,"Committee Needed"$$FG$ * Should Messages in PopUp queue get fwded to parent when task dies? -* Import Intel datasheets so we can use links in $LK,"Code",A="FI:::/Kernel/Memory/PageTables.CC"$ for documentation. I tried a PDF-to-text convertor and it wasn't acceptible. +* Import Intel datasheets so we can use links in $LK,"Code",A="FI:::/Kernel/Memory/PageTables.ZC"$ for documentation. I tried a PDF-to-text convertor and it wasn't acceptible. * Switch stmt with sparse cases? Maybe, ban sparse switch statements. @@ -305,11 +305,11 @@ $FG,5$$TX+CX,"Committee Needed"$$FG$ * SIMD in $LK,"Mat4x4MulXYZ",A="MN:Mat4x4MulXYZ"$? -* I use fixed-point in $LK,"Circle",A="MN:Circle"$(), $LK,"Ellipse",A="MN:Ellipse"$(), $LK,"Mat4x4MulXYZ",A="MN:Mat4x4MulXYZ"$(), $LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$() and others. God says I might want to change to float. $LK,"::/Demo/Lectures/FixedPoint.CC"$ $LK,"::/Demo/Lectures/FixedPointAdvanced.CC"$. +* I use fixed-point in $LK,"Circle",A="MN:Circle"$(), $LK,"Ellipse",A="MN:Ellipse"$(), $LK,"Mat4x4MulXYZ",A="MN:Mat4x4MulXYZ"$(), $LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$() and others. God says I might want to change to float. $LK,"::/Demo/Lectures/FixedPoint.ZC"$ $LK,"::/Demo/Lectures/FixedPointAdvanced.ZC"$. -* Note: We will never put multiple $LK,"Keyboard Tables",A="FI:::/Kernel/SerialDev/Keyboard.CC"$. Each country must make their own version of ZealOS. The $LK,"Intel Factory ROM",A="FF:::/Doc/Demands.DD,English"$ will have just English. Our $LK,"Charter",A="FI:::/Doc/Charter.DD"$ bans multiple country or architectures in the same version. +* Note: We will never put multiple $LK,"Keyboard Tables",A="FI:::/Kernel/SerialDev/Keyboard.ZC"$. Each country must make their own version of ZealOS. The $LK,"Intel Factory ROM",A="FF:::/Doc/Demands.DD,English"$ will have just English. Our $LK,"Charter",A="FI:::/Doc/Charter.DD"$ bans multiple country or architectures in the same version. -* 12 border chars in screen font codes 0x02-0x0D. $LK,"TextBorder",A="MN:TextBorder"$() $LK,"RawDumpRegs",A="MN:RawDumpRegs"$() $LK,"::/Demo/Games/CharDemo.CC"$. LineFeed shows-up in $FG,2$$FG$ PersonalMenu. +* 12 border chars in screen font codes 0x02-0x0D. $LK,"TextBorder",A="MN:TextBorder"$() $LK,"RawDumpRegs",A="MN:RawDumpRegs"$() $LK,"::/Demo/Games/CharDemo.ZC"$. LineFeed shows-up in $FG,2$$FG$ PersonalMenu. * Super-simple high speed serial needs flow control. $FG,2$$FG$ and $FG,2$$FG$? @@ -348,7 +348,7 @@ $FG,5$$TX+CX,"Inspirational Ideas"$$FG$ * Move stuff out of $LK,"Kernel",A="FI:::/Kernel/Kernel.PRJ"$ module. -* $$LK,L="FL:D:/Kernel/File.CC"$$ instead of A= +* $$LK,L="FL:D:/Kernel/File.ZC"$$ instead of A= * $$SP,B=1$$ instead of $$SP,BI=1$$ * $$CM+LE+RE is nasty @@ -360,7 +360,7 @@ $FG,5$$TX+CX,"Inspirational Ideas"$$FG$ * Compiler: More aggressive in $LK,"CompF2PushPop",A="MN:CompF2PushPop"$() with types besides MOV and F64. -* Playing with $LK,"::/Demo/Lectures/NegDisp.CC"$ on $LK,"CTask",A="MN:CTask"$? +* Playing with $LK,"::/Demo/Lectures/NegDisp.ZC"$ on $LK,"CTask",A="MN:CTask"$? $ID,5$$$=-CTASK_NEG_OFFSET offset(CTask.addr)==0 Spawn(): CAlloc() @@ -372,12 +372,12 @@ $ID,-5$ $FG,5$$TX+CX,"Test"$$FG$ -* $LK,"SpriteBitMap",A="FI:::/System/Gr/SpriteBitMap.CC"$: Grabscroll? +* $LK,"SpriteBitMap",A="FI:::/System/Gr/SpriteBitMap.ZC"$: Grabscroll? * Return ress for $LK,"GrBlot",A="MN:GrBlot"$, $LK,"GrRect",A="MN:GrRect"$, $LK,"GrPutChar",A="MN:GrPutChar"$? * Collision counts for $LK,"GrBlot",A="MN:GrBlot"$, $LK,"GrRect",A="MN:GrRect"$, $LK,"GrPutChar",A="MN:GrPutChar"$? -* $LK,"StrGet",A="MN:StrGet"$() or $LK,"CharGet",A="MN:CharGet"$() in $LK,"OSInstall",A="FI:::/Misc/OSInstall.CC"$ didn't like focus change. +* $LK,"StrGet",A="MN:StrGet"$() or $LK,"CharGet",A="MN:CharGet"$() in $LK,"OSInstall",A="FI:::/Misc/OSInstall.ZC"$ didn't like focus change. * Test on Dad's computer or other people's? @@ -387,7 +387,7 @@ $FG,5$$TX+CX,"Test"$$FG$ * $LK,"FileMgr",A="MN:FileMgr"$() help link scrolls out of window. -* $LK,"MouseHardDriverInstall",A="MN:MouseHardDriverInstall"$() throws exceptions? Doesn't work? Why mouse $LK,"0x9FC30",A="FF:::/Kernel/SerialDev/Mouse.CC,9FC"$? +* $LK,"MouseHardDriverInstall",A="MN:MouseHardDriverInstall"$() throws exceptions? Doesn't work? Why mouse $LK,"0x9FC30",A="FF:::/Kernel/SerialDev/Mouse.ZC,9FC"$? * VirtualBox MP reboot? @@ -408,7 +408,7 @@ $FG,5$$TX+CX,"Uncategorized"$$FG$ >Might want to do ZOOM in U8 graphics and convert screen capture to U8 >Might want to rev bit order -* This $LK,"Fs->catch_except = TRUE",A="FF:::/Kernel/Job.CC,Fs->catch_except = TRUE"$ causes problems because it +* This $LK,"Fs->catch_except = TRUE",A="FF:::/Kernel/Job.ZC,Fs->catch_except = TRUE"$ causes problems because it catches divide and out-of-mem. Not sure what to do, yet. * Release semaphores or break lock sema,usb_td diff --git a/src/Demo/AcctExample/Registry.CC b/src/Demo/AcctExample/Registry.ZC similarity index 100% rename from src/Demo/AcctExample/Registry.CC rename to src/Demo/AcctExample/Registry.ZC diff --git a/src/Demo/AcctExample/TOS/MakeTOS.CC b/src/Demo/AcctExample/TOS/MakeTOS.ZC similarity index 100% rename from src/Demo/AcctExample/TOS/MakeTOS.CC rename to src/Demo/AcctExample/TOS/MakeTOS.ZC diff --git a/src/Demo/AcctExample/TOS/TOSConfig.CC b/src/Demo/AcctExample/TOS/TOSConfig.ZC similarity index 100% rename from src/Demo/AcctExample/TOS/TOSConfig.CC rename to src/Demo/AcctExample/TOS/TOSConfig.ZC diff --git a/src/Demo/AcctExample/TOS/TOSDistro.CC b/src/Demo/AcctExample/TOS/TOSDistro.ZC similarity index 91% rename from src/Demo/AcctExample/TOS/TOSDistro.CC rename to src/Demo/AcctExample/TOS/TOSDistro.ZC index 4c93a04c..5a9c8f84 100755 --- a/src/Demo/AcctExample/TOS/TOSDistro.CC +++ b/src/Demo/AcctExample/TOS/TOSDistro.ZC @@ -1,4 +1,4 @@ -//The CONFIG defines are $LK,"~/TOS/TOSConfig.CC",A="FI:::/Demo/AcctExample/TOS/TOSConfig.CC"$. +//The CONFIG defines are $LK,"~/TOS/TOSConfig.ZC",A="FI:::/Demo/AcctExample/TOS/TOSConfig.ZC"$. #help_index "Misc/TOS/Distro" @@ -80,8 +80,8 @@ U0 DistroPrep() DelTree("/Demo/AcctExample/Sup2"); DelTree("/Demo/AcctExample/Sup3"); Del("/Demo/AcctExample/Test*"); - if (FileFind("~/Sup1/Sup1Utils/SortHeaders.CC")) - ExeFile("~/Sup1/Sup1Utils/SortHeaders.CC"); + if (FileFind("~/Sup1/Sup1Utils/SortHeaders.ZC")) + ExeFile("~/Sup1/Sup1Utils/SortHeaders.ZC"); CursorRemove("/*"); DelTree("/Demo/*.BI*"); @@ -112,16 +112,16 @@ U0 DebugDistroFilePrep() Copy("C:/Kernel/*.HH*", "A:/Kernel"); CopyTree("C:/Kernel/BlkDev", "A:/Kernel/BlkDev"); - Copy("C:/Home/Sup1/Sup1Distro/DebugStartOS.CC", "A:/StartOS.CC"); + Copy("C:/Home/Sup1/Sup1Distro/DebugStartOS.ZC", "A:/StartOS.ZC"); DirMake("A:/System"); - Copy("C:/Home/Sup1/Sup1Distro/DebugMakeSystem.CC", "A:/System/MakeSystem.CC"); - Copy("C:/Home/Sup1/Sup1Distro/DebugMount.CC", "A:/System"); - Copy("C:/System/AExts.CC", "A:/System"); - Copy("C:/System/AMath.CC", "A:/System"); - Copy("C:/System/Training.CC", "A:/System"); - Copy("C:/System/AMem.CC", "A:/System"); - Copy("C:/System/TaskRep.CC", "A:/System"); + Copy("C:/Home/Sup1/Sup1Distro/DebugMakeSystem.ZC", "A:/System/MakeSystem.ZC"); + Copy("C:/Home/Sup1/Sup1Distro/DebugMount.ZC", "A:/System"); + Copy("C:/System/AExts.ZC", "A:/System"); + Copy("C:/System/AMath.ZC", "A:/System"); + Copy("C:/System/Training.ZC", "A:/System"); + Copy("C:/System/AMem.ZC", "A:/System"); + Copy("C:/System/TaskRep.ZC", "A:/System"); FileWrite("C:" CONFIG_DEBUG_DISTRO_FILE, bd->RAM_disk, (bd->max_blk + 1) << BLK_SIZE_BITS); } @@ -164,7 +164,7 @@ U0 LiteDistroPrep() DirMake(TOS_DISTRO_DIR "/Home"); DelTree(TOS_DISTRO_DIR "/Apps"); DelTree(TOS_DISTRO_DIR "/Demo"); - Copy(TOS_DISTRO_DIR "/Demo/Games/Talons.CC", TOS_DISTRO_DIR "/Home"); + Copy(TOS_DISTRO_DIR "/Demo/Games/Talons.ZC", TOS_DISTRO_DIR "/Home"); Del(TOS_DISTRO_DIR "/" KERNEL_BIN_C); Del(TOS_DISTRO_DIR BOOT_DIR "/OldMBR.BIN.C"); Del(TOS_DISTRO_DIR BOOT_DIR "/BootMHD2.BIN.C"); @@ -248,7 +248,7 @@ I64 UpdateLineCounts() CopyTree("B:/TOS/TOS", "C:/Home"); DelTree("B:/TOS/TOS"); - DocTreeFWrite("C:/System/Define.CC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", res); + DocTreeFWrite("C:/System/Define.ZC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", res); DefinePrint("DD_ZEALOS_LOC", "%,d", res); "Total LOC:%12,d\n\n", res; @@ -383,6 +383,6 @@ public U0 TOSRegen() {//Generate distro ISO's TOSBootHDIns('C'); Once("PopUp(\"TOSRegen2;\");"); -// BootRAM("C:/Kernel/" KERNEL_BIN_C); //Boot to load $LK,"TOS_CONFIG",A="PF:::/Demo/AcctExample/TOS/TOSConfig.CC,TOS_CONFIG"$. - BootRAM("::" BOOT_DIR_KERNEL_BIN_C); //Boot to load $LK,"TOS_CONFIG",A="PF:::/Demo/AcctExample/TOS/TOSConfig.CC,TOS_CONFIG"$. +// BootRAM("C:/Kernel/" KERNEL_BIN_C); //Boot to load $LK,"TOS_CONFIG",A="PF:::/Demo/AcctExample/TOS/TOSConfig.ZC,TOS_CONFIG"$. + BootRAM("::" BOOT_DIR_KERNEL_BIN_C); //Boot to load $LK,"TOS_CONFIG",A="PF:::/Demo/AcctExample/TOS/TOSConfig.ZC,TOS_CONFIG"$. } diff --git a/src/Demo/AcctExample/TOS/TOSExtern.CC b/src/Demo/AcctExample/TOS/TOSExtern.ZC similarity index 100% rename from src/Demo/AcctExample/TOS/TOSExtern.CC rename to src/Demo/AcctExample/TOS/TOSExtern.ZC diff --git a/src/Demo/AcctExample/TOS/TOSMisc.CC b/src/Demo/AcctExample/TOS/TOSMisc.ZC similarity index 100% rename from src/Demo/AcctExample/TOS/TOSMisc.CC rename to src/Demo/AcctExample/TOS/TOSMisc.ZC diff --git a/src/Demo/AcctExample/TOS/TOSTheme.CC b/src/Demo/AcctExample/TOS/TOSTheme.ZC similarity index 100% rename from src/Demo/AcctExample/TOS/TOSTheme.CC rename to src/Demo/AcctExample/TOS/TOSTheme.ZC diff --git a/src/Demo/Asm/AsmAndC1.CC b/src/Demo/Asm/AsmAndC1.ZC similarity index 100% rename from src/Demo/Asm/AsmAndC1.CC rename to src/Demo/Asm/AsmAndC1.ZC diff --git a/src/Demo/Asm/AsmAndC2.CC b/src/Demo/Asm/AsmAndC2.ZC similarity index 96% rename from src/Demo/Asm/AsmAndC2.CC rename to src/Demo/Asm/AsmAndC2.ZC index 68f8c2b6..6021d98f 100755 --- a/src/Demo/Asm/AsmAndC2.CC +++ b/src/Demo/Asm/AsmAndC2.ZC @@ -15,7 +15,7 @@ asm { JIFFIES_MESSAGE: DU8 "Jiffies:", 0; -//See $LK,"::/Kernel/StrA.CC",A="FL:::/Kernel/StrA.CC,1"$ and $LK,"::/Kernel/KUtils.CC"$. +//See $LK,"::/Kernel/StrA.ZC",A="FL:::/Kernel/StrA.ZC,1"$ and $LK,"::/Kernel/KUtils.ZC"$. _BEEPS2:: //You can clobber RAX,RBX,RCX,RDX,R8,R9. The compiler expects that. diff --git a/src/Demo/Asm/AsmAndC3.CC b/src/Demo/Asm/AsmAndC3.ZC similarity index 100% rename from src/Demo/Asm/AsmAndC3.CC rename to src/Demo/Asm/AsmAndC3.ZC diff --git a/src/Demo/Asm/AsmHelloWorld.CC b/src/Demo/Asm/AsmHelloWorld.ZC similarity index 95% rename from src/Demo/Asm/AsmHelloWorld.CC rename to src/Demo/Asm/AsmHelloWorld.ZC index 37729ad7..842dfee9 100755 --- a/src/Demo/Asm/AsmHelloWorld.CC +++ b/src/Demo/Asm/AsmHelloWorld.ZC @@ -5,7 +5,7 @@ error, like when repeatedly #including it from the cmd line. These are many useful kernel -routines $LK,"::/Kernel/StrA.CC",A="FF:::/Kernel/StrA.CC,PUT_CHARS"$ +routines $LK,"::/Kernel/StrA.ZC",A="FF:::/Kernel/StrA.ZC,PUT_CHARS"$ intended to be called from asm. Generally, they preserve registers. diff --git a/src/Demo/Asm/BuzzFizz.CC b/src/Demo/Asm/BuzzFizz.ZC similarity index 100% rename from src/Demo/Asm/BuzzFizz.CC rename to src/Demo/Asm/BuzzFizz.ZC diff --git a/src/Demo/Asm/DivByHand.CC b/src/Demo/Asm/DivByHand.ZC similarity index 100% rename from src/Demo/Asm/DivByHand.CC rename to src/Demo/Asm/DivByHand.ZC diff --git a/src/Demo/Asm/MulByHand.CC b/src/Demo/Asm/MulByHand.ZC similarity index 100% rename from src/Demo/Asm/MulByHand.CC rename to src/Demo/Asm/MulByHand.ZC diff --git a/src/Demo/Asm/PutDec.CC b/src/Demo/Asm/PutDec.ZC similarity index 100% rename from src/Demo/Asm/PutDec.CC rename to src/Demo/Asm/PutDec.ZC diff --git a/src/Demo/Carry.CC b/src/Demo/Carry.ZC similarity index 100% rename from src/Demo/Carry.CC rename to src/Demo/Carry.ZC diff --git a/src/Demo/ClassMeta.CC b/src/Demo/ClassMeta.ZC similarity index 97% rename from src/Demo/ClassMeta.CC rename to src/Demo/ClassMeta.ZC index f516801b..cb3feb5d 100755 --- a/src/Demo/ClassMeta.CC +++ b/src/Demo/ClassMeta.ZC @@ -28,7 +28,7 @@ class Test2Struct }; U0 DumpStruct(U8 *_d, U8 *class_name=lastclass) -{//lastclass is keyword. See $LK,"::/Demo/LastClass.CC"$. +{//lastclass is keyword. See $LK,"::/Demo/LastClass.ZC"$. CHashClass *tmpc = HashFind(class_name, Fs->hash_table, HTT_CLASS); U8 *print_str; I64 *q, default_val; diff --git a/src/Demo/CompileDemo.CC b/src/Demo/CompileDemo.ZC similarity index 100% rename from src/Demo/CompileDemo.CC rename to src/Demo/CompileDemo.ZC diff --git a/src/Demo/DateTime.CC b/src/Demo/DateTime.ZC similarity index 100% rename from src/Demo/DateTime.CC rename to src/Demo/DateTime.ZC diff --git a/src/Demo/DebugDemo.CC b/src/Demo/DebugDemo.ZC similarity index 100% rename from src/Demo/DebugDemo.CC rename to src/Demo/DebugDemo.ZC diff --git a/src/Demo/Define.CC b/src/Demo/Define.ZC similarity index 100% rename from src/Demo/Define.CC rename to src/Demo/Define.ZC diff --git a/src/Demo/Directives.CC b/src/Demo/Directives.ZC similarity index 100% rename from src/Demo/Directives.CC rename to src/Demo/Directives.ZC diff --git a/src/Demo/Disk/DataBase.CC b/src/Demo/Disk/DataBase.ZC similarity index 100% rename from src/Demo/Disk/DataBase.CC rename to src/Demo/Disk/DataBase.ZC diff --git a/src/Demo/Disk/DiskRaw.CC b/src/Demo/Disk/DiskRaw.ZC similarity index 100% rename from src/Demo/Disk/DiskRaw.CC rename to src/Demo/Disk/DiskRaw.ZC diff --git a/src/Demo/Disk/FPrintF.CC b/src/Demo/Disk/FPrintF.ZC similarity index 100% rename from src/Demo/Disk/FPrintF.CC rename to src/Demo/Disk/FPrintF.ZC diff --git a/src/Demo/Disk/SerializeTree.CC b/src/Demo/Disk/SerializeTree.ZC similarity index 100% rename from src/Demo/Disk/SerializeTree.CC rename to src/Demo/Disk/SerializeTree.ZC diff --git a/src/Demo/Disk/UnusedSpaceRep.CC b/src/Demo/Disk/UnusedSpaceRep.ZC similarity index 100% rename from src/Demo/Disk/UnusedSpaceRep.CC rename to src/Demo/Disk/UnusedSpaceRep.ZC diff --git a/src/Demo/DolDoc/CallBack.CC b/src/Demo/DolDoc/CallBack.ZC similarity index 97% rename from src/Demo/DolDoc/CallBack.CC rename to src/Demo/DolDoc/CallBack.ZC index 7485a04b..ed443895 100755 --- a/src/Demo/DolDoc/CallBack.CC +++ b/src/Demo/DolDoc/CallBack.ZC @@ -35,7 +35,7 @@ U0 DoIt() //Flags are explained here: //$LK,"::/Doc/DolDocOverview.DD"$ $LK,"::/Doc/Widget.DD"$ - //$LK,"Dollar Flags",A="MN:DOCEf_TAG"$ $LK,"ST_DOC_FLAGS",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$ + //$LK,"Dollar Flags",A="MN:DOCEf_TAG"$ $LK,"ST_DOC_FLAGS",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$ doc_e->tag_cb = &tSCB; DocPrint(bdoc, "$$FG$$"); DocUnlock(bdoc); diff --git a/src/Demo/DolDoc/ClickCallBack.CC b/src/Demo/DolDoc/ClickCallBack.ZC similarity index 95% rename from src/Demo/DolDoc/ClickCallBack.CC rename to src/Demo/DolDoc/ClickCallBack.ZC index ceab5bfe..8029f99c 100755 --- a/src/Demo/DolDoc/ClickCallBack.CC +++ b/src/Demo/DolDoc/ClickCallBack.ZC @@ -23,7 +23,7 @@ U0 ClickCallBack() //Flags are explained here: //$LK,"::/Doc/DolDocOverview.DD"$ $LK,"::/Doc/Widget.DD"$ - //$LK,"Dollar Flags",A="MN:DOCEf_TAG"$ $LK,"ST_DOC_FLAGS",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$ + //$LK,"Dollar Flags",A="MN:DOCEf_TAG"$ $LK,"ST_DOC_FLAGS",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$ "(Not preserved if you press .)\n\n"; doc_e->left_cb = &MyLeftCB1; DocUnlock(DocPut); diff --git a/src/Demo/DolDoc/CursorMove.CC b/src/Demo/DolDoc/CursorMove.ZC similarity index 100% rename from src/Demo/DolDoc/CursorMove.CC rename to src/Demo/DolDoc/CursorMove.ZC diff --git a/src/Demo/DolDoc/Data.CC b/src/Demo/DolDoc/Data.ZC similarity index 95% rename from src/Demo/DolDoc/Data.CC rename to src/Demo/DolDoc/Data.ZC index ab2d6ef6..4551a49b 100755 --- a/src/Demo/DolDoc/Data.CC +++ b/src/Demo/DolDoc/Data.ZC @@ -8,7 +8,7 @@ -P Means it is a string variable, basically. ,32 sets the tag string width. - See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$. + See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$. ,RT=I16 means the value is 2 bytes. See $LK,"DocDataFormat",A="MN:DocDataFormat"$() and $LK,"DocDataScan",A="MN:DocDataScan"$(). diff --git a/src/Demo/DolDoc/DefineStr.CC b/src/Demo/DolDoc/DefineStr.ZC similarity index 100% rename from src/Demo/DolDoc/DefineStr.CC rename to src/Demo/DolDoc/DefineStr.ZC diff --git a/src/Demo/DolDoc/FileRead.CC b/src/Demo/DolDoc/FileRead.ZC similarity index 95% rename from src/Demo/DolDoc/FileRead.CC rename to src/Demo/DolDoc/FileRead.ZC index bc13f9d1..30882055 100755 --- a/src/Demo/DolDoc/FileRead.CC +++ b/src/Demo/DolDoc/FileRead.ZC @@ -34,7 +34,7 @@ public U0 DocProfile(U8 *filename,I64 flags) "See $$LK,\"CDocEntry\",A=\"MN:CDocEntry\"$$, " "$$LK,\"Doc Type Defines\",A=\"MN:DOCT_TEXT\"$$ and " "$$LK,\"Doc Type Codes\"," - "A=\"FF:::/System/DolDoc/DocInit.CC,ST_DOC_CMDS\"$$.\n" + "A=\"FF:::/System/DolDoc/DocInit.ZC,ST_DOC_CMDS\"$$.\n" "$$FG$$"; for (i = 0; i < DOCT_TYPES_NUM; i++) if (cmd_stats[i]) @@ -54,7 +54,7 @@ public U0 DocProfile(U8 *filename,I64 flags) "$$GREEN$$\n'$$PURPLE$$doc_e->de_flags$$GREEN$$' is 64-bit. " "See $$LK,\"Doc Flag Defines\",A=\"MN:DOCEf_TAG\"$$ and " "$$LK,\"Doc Flag Codes\"," - "A=\"FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS\"$$.\n" + "A=\"FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS\"$$.\n" "$$FG$$"; for (i = 0; i < 64; i++) if (flags_stats[i]) diff --git a/src/Demo/DolDoc/Form.CC b/src/Demo/DolDoc/Form.ZC similarity index 100% rename from src/Demo/DolDoc/Form.CC rename to src/Demo/DolDoc/Form.ZC diff --git a/src/Demo/DolDoc/MenuBttn.CC b/src/Demo/DolDoc/MenuBttn.ZC similarity index 100% rename from src/Demo/DolDoc/MenuBttn.CC rename to src/Demo/DolDoc/MenuBttn.ZC diff --git a/src/Demo/DolDoc/MenuSprite.CC b/src/Demo/DolDoc/MenuSprite.ZC similarity index 100% rename from src/Demo/DolDoc/MenuSprite.CC rename to src/Demo/DolDoc/MenuSprite.ZC diff --git a/src/Demo/DolDoc/NumBible.CC b/src/Demo/DolDoc/NumBible.ZC similarity index 100% rename from src/Demo/DolDoc/NumBible.CC rename to src/Demo/DolDoc/NumBible.ZC diff --git a/src/Demo/DolDoc/TextDemo.CC b/src/Demo/DolDoc/TextDemo.ZC similarity index 85% rename from src/Demo/DolDoc/TextDemo.CC rename to src/Demo/DolDoc/TextDemo.ZC index ee3760bb..4d4d3516 100755 --- a/src/Demo/DolDoc/TextDemo.CC +++ b/src/Demo/DolDoc/TextDemo.ZC @@ -4,7 +4,7 @@ "Blink : $$BK,1$$Test$$BK,0$$\n\n" "Invert : $$IV,1$$Test$$IV,0$$\n\n" "UnderLine: $$UL,1$$Test$$UL,0$$\n\n" - "Link : $$LK,\"KStart16.CC\",A=\"::/Kernel/KStart16.CC\"$$\n\n\n" + "Link : $$LK,\"KStart16.ZC\",A=\"::/Kernel/KStart16.ZC\"$$\n\n\n" "Bttn : $$BT-X,\"OKAY\",LE=1$$\n\n\n\n"; //You can do it this way if you like. @@ -16,6 +16,6 @@ "Invert : $IV,1$Test$IV,0$\n\n" "UnderLine: $UL,1$Test$UL,0$\n\n" // on this link to toggle individual commands. - "Link : $LK,"KStart16.CC",A="::/Kernel/KStart16.CC"$\n\n\n" + "Link : $LK,"KStart16.ZC",A="::/Kernel/KStart16.ZC"$\n\n\n" "Bttn : $BT,"OKAY",LE=1$\n\n\n\n"; diff --git a/src/Demo/DolDoc/TreeDemo.CC b/src/Demo/DolDoc/TreeDemo.ZC similarity index 100% rename from src/Demo/DolDoc/TreeDemo.CC rename to src/Demo/DolDoc/TreeDemo.ZC diff --git a/src/Demo/DolDoc/UnusedDefine.CC b/src/Demo/DolDoc/UnusedDefine.ZC similarity index 100% rename from src/Demo/DolDoc/UnusedDefine.CC rename to src/Demo/DolDoc/UnusedDefine.ZC diff --git a/src/Demo/Exceptions.CC b/src/Demo/Exceptions.ZC similarity index 100% rename from src/Demo/Exceptions.CC rename to src/Demo/Exceptions.ZC diff --git a/src/Demo/ExtChars.CC b/src/Demo/ExtChars.ZC similarity index 77% rename from src/Demo/ExtChars.CC rename to src/Demo/ExtChars.ZC index a9f18597..dd93717e 100755 --- a/src/Demo/ExtChars.CC +++ b/src/Demo/ExtChars.ZC @@ -28,7 +28,7 @@ U0 SrcExample() } SrcExample; -//See $LK,"::/Demo/ScreenCodes.CC"$, $LK,"::/Demo/Graphics/CharAnimation.CC"$, -//$LK,"::/Demo/Games/CharDemo.CC"$ and $LK,"::/Demo/Graphics/FontEd.CC"$. +//See $LK,"::/Demo/ScreenCodes.ZC"$, $LK,"::/Demo/Graphics/CharAnimation.ZC"$, +//$LK,"::/Demo/Games/CharDemo.ZC"$ and $LK,"::/Demo/Graphics/FontEd.ZC"$. //See $LK,"char_bmp_alpha",A="MN:char_bmp_alpha"$ and $LK,"char_bmp_alpha_numeric",A="MN:char_bmp_alpha_numeric"$. diff --git a/src/Demo/Games/BattleLines.CC b/src/Demo/Games/BattleLines.ZC similarity index 99% rename from src/Demo/Games/BattleLines.CC rename to src/Demo/Games/BattleLines.ZC index 9928de6b..5208c7a3 100755 --- a/src/Demo/Games/BattleLines.CC +++ b/src/Demo/Games/BattleLines.ZC @@ -1,4 +1,4 @@ -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. $BG,2$ diff --git a/src/Demo/Games/BigGuns.CC b/src/Demo/Games/BigGuns.ZC similarity index 98% rename from src/Demo/Games/BigGuns.CC rename to src/Demo/Games/BigGuns.ZC index 3eafed4660db208a26d4786b6415e7019fcbaefb..86991b006e25ba4224cde77a9d7e181b5f621f9c 100755 GIT binary patch delta 12 Tcmca=cGYZxHDlC98%b#ZB0L0M delta 12 Tcmca=cGYZxHKX%J8%b#ZA;|win_width; j++) //By the time you clip to window and handle Fs->scroll_x, Fs->scroll_y, //it is too much trouble to do raw access to gr.text_base like we do - //in $LK,"::/Demo/Games/Maze.CC"$. + //in $LK,"::/Demo/Games/Maze.ZC"$. TextChar(task, FALSE, j, i, *ptr++); } } diff --git a/src/Demo/Games/Chess.CC b/src/Demo/Games/Chess.ZC similarity index 100% rename from src/Demo/Games/Chess.CC rename to src/Demo/Games/Chess.ZC diff --git a/src/Demo/Games/CircleTrace.CC b/src/Demo/Games/CircleTrace.ZC similarity index 100% rename from src/Demo/Games/CircleTrace.CC rename to src/Demo/Games/CircleTrace.ZC diff --git a/src/Demo/Games/Collision.CC b/src/Demo/Games/Collision.ZC similarity index 96% rename from src/Demo/Games/Collision.CC rename to src/Demo/Games/Collision.ZC index f7c38c34c3598462ff51c47e69bd856653271bc7..49d797940c17bc807700f1680fd0e1e3a41b7eef 100755 GIT binary patch delta 17 Zcmdm@v_)xxHDlC7n>5C#jf*D=0023f237z7 delta 17 Zcmdm@v_)xxHKX%Hn>0q}jf*D=001~a1}Fdk diff --git a/src/Demo/Games/Digits.CC b/src/Demo/Games/Digits.ZC similarity index 96% rename from src/Demo/Games/Digits.CC rename to src/Demo/Games/Digits.ZC index 7a9090de..70959a7f 100755 --- a/src/Demo/Games/Digits.CC +++ b/src/Demo/Games/Digits.ZC @@ -3,7 +3,7 @@ //gives a name to it. Strings like //this are known as Define entries. -//See $LK,"ST_RAINBOW_10",A="FF:::/System/Gr/GrPalette.CC,ST_RAINBOW_10"$ +//See $LK,"ST_RAINBOW_10",A="FF:::/System/Gr/GrPalette.ZC,ST_RAINBOW_10"$ U0 PrintDigit(U8 ch) { diff --git a/src/Demo/Games/DunGen.CC b/src/Demo/Games/DunGen.ZC similarity index 99% rename from src/Demo/Games/DunGen.CC rename to src/Demo/Games/DunGen.ZC index 2ad40e30..2a8151f2 100755 --- a/src/Demo/Games/DunGen.CC +++ b/src/Demo/Games/DunGen.ZC @@ -111,7 +111,7 @@ U0 DrawIt(CTask *task, CDC *dc) dc_t->flags |= DCF_TRANSFORMATION; //You could make it much more efficient - //if you did it like $LK,"::/Demo/Games/BigGuns.CC"$ + //if you did it like $LK,"::/Demo/Games/BigGuns.ZC"$ //with a $LK,"CDC",A="MN:CDC"$. for (y = -SCREEN_HEIGHT / 2; y < SCREEN_HEIGHT / 2; y++) diff --git a/src/Demo/Games/ElephantWalk.CC b/src/Demo/Games/ElephantWalk.ZC similarity index 100% rename from src/Demo/Games/ElephantWalk.CC rename to src/Demo/Games/ElephantWalk.ZC diff --git a/src/Demo/Games/FlapBat.CC b/src/Demo/Games/FlapBat.ZC similarity index 100% rename from src/Demo/Games/FlapBat.CC rename to src/Demo/Games/FlapBat.ZC diff --git a/src/Demo/Games/FlatTops.CC b/src/Demo/Games/FlatTops.ZC similarity index 100% rename from src/Demo/Games/FlatTops.CC rename to src/Demo/Games/FlatTops.ZC diff --git a/src/Demo/Games/Halogen.CC b/src/Demo/Games/Halogen.ZC similarity index 100% rename from src/Demo/Games/Halogen.CC rename to src/Demo/Games/Halogen.ZC diff --git a/src/Demo/Games/MassSpring.CC b/src/Demo/Games/MassSpring.ZC similarity index 100% rename from src/Demo/Games/MassSpring.CC rename to src/Demo/Games/MassSpring.ZC diff --git a/src/Demo/Games/Maze.CC b/src/Demo/Games/Maze.ZC similarity index 100% rename from src/Demo/Games/Maze.CC rename to src/Demo/Games/Maze.ZC diff --git a/src/Demo/Games/RainDrops.CC b/src/Demo/Games/RainDrops.ZC similarity index 100% rename from src/Demo/Games/RainDrops.CC rename to src/Demo/Games/RainDrops.ZC diff --git a/src/Demo/Games/RawHide.CC b/src/Demo/Games/RawHide.ZC similarity index 99% rename from src/Demo/Games/RawHide.CC rename to src/Demo/Games/RawHide.ZC index 4d577303..e5ed6230 100755 --- a/src/Demo/Games/RawHide.CC +++ b/src/Demo/Games/RawHide.ZC @@ -1,4 +1,4 @@ -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. RegDefault("ZealOS/RawHide", "F64 best_score=9999;\n"); RegExe("ZealOS/RawHide"); diff --git a/src/Demo/Games/Rocket.CC b/src/Demo/Games/Rocket.ZC similarity index 100% rename from src/Demo/Games/Rocket.CC rename to src/Demo/Games/Rocket.ZC diff --git a/src/Demo/Games/RocketScience.CC b/src/Demo/Games/RocketScience.ZC similarity index 100% rename from src/Demo/Games/RocketScience.CC rename to src/Demo/Games/RocketScience.ZC diff --git a/src/Demo/Games/Squirt.CC b/src/Demo/Games/Squirt.ZC similarity index 100% rename from src/Demo/Games/Squirt.CC rename to src/Demo/Games/Squirt.ZC diff --git a/src/Demo/Games/Stadium/Stadium.CC b/src/Demo/Games/Stadium/Stadium.ZC similarity index 100% rename from src/Demo/Games/Stadium/Stadium.CC rename to src/Demo/Games/Stadium/Stadium.ZC diff --git a/src/Demo/Games/Stadium/StadiumGen.CC b/src/Demo/Games/Stadium/StadiumGen.ZC similarity index 100% rename from src/Demo/Games/Stadium/StadiumGen.CC rename to src/Demo/Games/Stadium/StadiumGen.ZC diff --git a/src/Demo/Games/Talons.CC b/src/Demo/Games/Talons.ZC similarity index 99% rename from src/Demo/Games/Talons.CC rename to src/Demo/Games/Talons.ZC index b429266d..0428f107 100755 --- a/src/Demo/Games/Talons.CC +++ b/src/Demo/Games/Talons.ZC @@ -1,4 +1,4 @@ -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. RegDefault("ZealOS/Talons", "F64 best_score=9999;\n"); RegExe("ZealOS/Talons"); diff --git a/src/Demo/Games/TheDead.CC b/src/Demo/Games/TheDead.ZC similarity index 100% rename from src/Demo/Games/TheDead.CC rename to src/Demo/Games/TheDead.ZC diff --git a/src/Demo/Games/TicTacToe.CC b/src/Demo/Games/TicTacToe.ZC similarity index 100% rename from src/Demo/Games/TicTacToe.CC rename to src/Demo/Games/TicTacToe.ZC diff --git a/src/Demo/Games/TreeCheckers.CC b/src/Demo/Games/TreeCheckers.ZC similarity index 100% rename from src/Demo/Games/TreeCheckers.CC rename to src/Demo/Games/TreeCheckers.ZC diff --git a/src/Demo/Games/Varoom.CC b/src/Demo/Games/Varoom.ZC similarity index 100% rename from src/Demo/Games/Varoom.CC rename to src/Demo/Games/Varoom.ZC diff --git a/src/Demo/Games/Wenceslas.CC b/src/Demo/Games/Wenceslas.ZC similarity index 100% rename from src/Demo/Games/Wenceslas.CC rename to src/Demo/Games/Wenceslas.ZC diff --git a/src/Demo/Games/Whap.CC b/src/Demo/Games/Whap.ZC similarity index 100% rename from src/Demo/Games/Whap.CC rename to src/Demo/Games/Whap.ZC diff --git a/src/Demo/Games/Zing.CC b/src/Demo/Games/Zing.ZC similarity index 100% rename from src/Demo/Games/Zing.CC rename to src/Demo/Games/Zing.ZC diff --git a/src/Demo/Games/ZoneOut.CC b/src/Demo/Games/ZoneOut.ZC similarity index 100% rename from src/Demo/Games/ZoneOut.CC rename to src/Demo/Games/ZoneOut.ZC diff --git a/src/Demo/GlobalVars.CC b/src/Demo/GlobalVars.ZC similarity index 100% rename from src/Demo/GlobalVars.CC rename to src/Demo/GlobalVars.ZC diff --git a/src/Demo/Graphics/32BitColor.CC b/src/Demo/Graphics/32BitColor.ZC similarity index 100% rename from src/Demo/Graphics/32BitColor.CC rename to src/Demo/Graphics/32BitColor.ZC diff --git a/src/Demo/Graphics/32BitPaint.CC b/src/Demo/Graphics/32BitPaint.ZC similarity index 100% rename from src/Demo/Graphics/32BitPaint.CC rename to src/Demo/Graphics/32BitPaint.ZC diff --git a/src/Demo/Graphics/3DPoly.CC b/src/Demo/Graphics/3DPoly.ZC similarity index 100% rename from src/Demo/Graphics/3DPoly.CC rename to src/Demo/Graphics/3DPoly.ZC diff --git a/src/Demo/Graphics/BSpline.CC b/src/Demo/Graphics/BSpline.ZC similarity index 100% rename from src/Demo/Graphics/BSpline.CC rename to src/Demo/Graphics/BSpline.ZC diff --git a/src/Demo/Graphics/Blot.CC b/src/Demo/Graphics/Blot.ZC similarity index 100% rename from src/Demo/Graphics/Blot.CC rename to src/Demo/Graphics/Blot.ZC diff --git a/src/Demo/Graphics/Bounce.CC b/src/Demo/Graphics/Bounce.ZC similarity index 98% rename from src/Demo/Graphics/Bounce.CC rename to src/Demo/Graphics/Bounce.ZC index 598c7aeb..dd118662 100755 --- a/src/Demo/Graphics/Bounce.CC +++ b/src/Demo/Graphics/Bounce.ZC @@ -1,4 +1,4 @@ -//Uses $LK,"fixed-point-arithmetic",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point-arithmetic",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 x[16], y[16], dx[16], dy[16]; diff --git a/src/Demo/Graphics/Box.CC b/src/Demo/Graphics/Box.ZC similarity index 100% rename from src/Demo/Graphics/Box.CC rename to src/Demo/Graphics/Box.ZC diff --git a/src/Demo/Graphics/Cartesian.CC b/src/Demo/Graphics/Cartesian.ZC similarity index 96% rename from src/Demo/Graphics/Cartesian.CC rename to src/Demo/Graphics/Cartesian.ZC index c7830ada..cf2e9dc2 100755 --- a/src/Demo/Graphics/Cartesian.CC +++ b/src/Demo/Graphics/Cartesian.ZC @@ -54,4 +54,4 @@ Cartesian; //For better performance, compile the expression entered by the //user one time with $LK,"LexExpression2Bin",A="MN:LexExpression2Bin"$() and use $LK,"Call",A="MN:Call"$(). -//See $LK,"::/Demo/CompileDemo.CC"$. +//See $LK,"::/Demo/CompileDemo.ZC"$. diff --git a/src/Demo/Graphics/CharAnimation.CC b/src/Demo/Graphics/CharAnimation.ZC similarity index 78% rename from src/Demo/Graphics/CharAnimation.CC rename to src/Demo/Graphics/CharAnimation.ZC index 1aa007c8..13045e7e 100755 --- a/src/Demo/Graphics/CharAnimation.CC +++ b/src/Demo/Graphics/CharAnimation.ZC @@ -1,7 +1,7 @@ U8 *old_font = text.font; -// See $LK,"::/Kernel/FontStd.CC"$, $LK,"::/Demo/ScreenCodes.CC"$, -//$LK,"::/Demo/ExtChars.CC"$, and $LK,"::/Demo/Graphics/FontEd.CC"$. +// See $LK,"::/Kernel/FontStd.ZC"$, $LK,"::/Demo/ScreenCodes.ZC"$, +//$LK,"::/Demo/ExtChars.ZC"$, and $LK,"::/Demo/Graphics/FontEd.ZC"$. U64 waves[4] = {0x0011AA440011AA44,0x0022558800225588,0x0044AA110044AA11,0x0088552200885522}; diff --git a/src/Demo/Graphics/Clock.CC b/src/Demo/Graphics/Clock.ZC similarity index 100% rename from src/Demo/Graphics/Clock.CC rename to src/Demo/Graphics/Clock.ZC diff --git a/src/Demo/Graphics/Collision.CC b/src/Demo/Graphics/Collision.ZC similarity index 100% rename from src/Demo/Graphics/Collision.CC rename to src/Demo/Graphics/Collision.ZC diff --git a/src/Demo/Graphics/CommonAncestor.CC b/src/Demo/Graphics/CommonAncestor.ZC similarity index 98% rename from src/Demo/Graphics/CommonAncestor.CC rename to src/Demo/Graphics/CommonAncestor.ZC index 3ff839cd..8fde4af7 100755 --- a/src/Demo/Graphics/CommonAncestor.CC +++ b/src/Demo/Graphics/CommonAncestor.ZC @@ -128,5 +128,5 @@ TreeCommonAncestor; Be careful with recursive routines in ZealOS because the stack does not grow and will overflow. -See $LK,"::/Demo/StackGrow.CC"$. +See $LK,"::/Demo/StackGrow.ZC"$. */ diff --git a/src/Demo/Graphics/Doodle.CC b/src/Demo/Graphics/Doodle.ZC similarity index 100% rename from src/Demo/Graphics/Doodle.CC rename to src/Demo/Graphics/Doodle.ZC diff --git a/src/Demo/Graphics/EdSprite.CC b/src/Demo/Graphics/EdSprite.ZC similarity index 100% rename from src/Demo/Graphics/EdSprite.CC rename to src/Demo/Graphics/EdSprite.ZC diff --git a/src/Demo/Graphics/Elephant.CC b/src/Demo/Graphics/Elephant.ZC similarity index 100% rename from src/Demo/Graphics/Elephant.CC rename to src/Demo/Graphics/Elephant.ZC diff --git a/src/Demo/Graphics/Extents.CC b/src/Demo/Graphics/Extents.ZC similarity index 100% rename from src/Demo/Graphics/Extents.CC rename to src/Demo/Graphics/Extents.ZC diff --git a/src/Demo/Graphics/FontEd.CC b/src/Demo/Graphics/FontEd.ZC similarity index 94% rename from src/Demo/Graphics/FontEd.CC rename to src/Demo/Graphics/FontEd.ZC index c8e1e10f..35422e8e 100755 --- a/src/Demo/Graphics/FontEd.CC +++ b/src/Demo/Graphics/FontEd.ZC @@ -13,11 +13,11 @@ You can load it with: If you want to change the system font permanently, save to a file with this font editor program -and cut and paste the code into $LK,"::/Kernel/FontStd.CC"$. +and cut and paste the code into $LK,"::/Kernel/FontStd.ZC"$. You will need to recompile Kernel by calling $LK,"BootHDIns",A="MN:BootHDIns"$(). -See $LK,"::/Demo/ExtChars.CC"$, $LK,"::/Demo/Games/CharDemo.CC"$, -$LK,"::/Demo/Graphics/CharAnimation.CC"$ and $LK,"::/Demo/ScreenCodes.CC"$. +See $LK,"::/Demo/ExtChars.ZC"$, $LK,"::/Demo/Games/CharDemo.ZC"$, +$LK,"::/Demo/Graphics/CharAnimation.ZC"$ and $LK,"::/Demo/ScreenCodes.ZC"$. */ #define BLOW_UP_CHAR_X (18 * FONT_WIDTH) diff --git a/src/Demo/Graphics/GrDir.CC b/src/Demo/Graphics/GrDir.ZC similarity index 97% rename from src/Demo/Graphics/GrDir.CC rename to src/Demo/Graphics/GrDir.ZC index 4df2bcdc9efb7ae839b57ed0d7a14cb9117d4049..6a04e7db2830b3109789cb94ac852fa0c8ef8af5 100755 GIT binary patch delta 26 gcmbR4Jl%Q1CB~?Ym)V&aqc-1WUc?Qg>i8vv0FE{ZUjP6A delta 26 gcmbR4Jl%Q1B}V6sm)V&aoj2cRUc?Qg>i8vv0E)~B8UO$Q diff --git a/src/Demo/Graphics/Grid.CC b/src/Demo/Graphics/Grid.ZC similarity index 100% rename from src/Demo/Graphics/Grid.CC rename to src/Demo/Graphics/Grid.ZC diff --git a/src/Demo/Graphics/Hanoi.CC b/src/Demo/Graphics/Hanoi.ZC similarity index 100% rename from src/Demo/Graphics/Hanoi.CC rename to src/Demo/Graphics/Hanoi.ZC diff --git a/src/Demo/Graphics/Lattice.CC b/src/Demo/Graphics/Lattice.ZC similarity index 100% rename from src/Demo/Graphics/Lattice.CC rename to src/Demo/Graphics/Lattice.ZC diff --git a/src/Demo/Graphics/Life.CC b/src/Demo/Graphics/Life.ZC similarity index 100% rename from src/Demo/Graphics/Life.CC rename to src/Demo/Graphics/Life.ZC diff --git a/src/Demo/Graphics/LightTable.CC b/src/Demo/Graphics/LightTable.ZC similarity index 100% rename from src/Demo/Graphics/LightTable.CC rename to src/Demo/Graphics/LightTable.ZC diff --git a/src/Demo/Graphics/Lines.CC b/src/Demo/Graphics/Lines.ZC similarity index 100% rename from src/Demo/Graphics/Lines.CC rename to src/Demo/Graphics/Lines.ZC diff --git a/src/Demo/Graphics/LowPassFilter.CC b/src/Demo/Graphics/LowPassFilter.ZC similarity index 100% rename from src/Demo/Graphics/LowPassFilter.CC rename to src/Demo/Graphics/LowPassFilter.ZC diff --git a/src/Demo/Graphics/MathAudioDemo.CC b/src/Demo/Graphics/MathAudioDemo.ZC similarity index 100% rename from src/Demo/Graphics/MathAudioDemo.CC rename to src/Demo/Graphics/MathAudioDemo.ZC diff --git a/src/Demo/Graphics/MouseDemo.CC b/src/Demo/Graphics/MouseDemo.ZC similarity index 100% rename from src/Demo/Graphics/MouseDemo.CC rename to src/Demo/Graphics/MouseDemo.ZC diff --git a/src/Demo/Graphics/NetOfDots.CC b/src/Demo/Graphics/NetOfDots.ZC similarity index 100% rename from src/Demo/Graphics/NetOfDots.CC rename to src/Demo/Graphics/NetOfDots.ZC diff --git a/src/Demo/Graphics/Palette.CC b/src/Demo/Graphics/Palette.ZC similarity index 100% rename from src/Demo/Graphics/Palette.CC rename to src/Demo/Graphics/Palette.ZC diff --git a/src/Demo/Graphics/PanText.CC b/src/Demo/Graphics/PanText.ZC similarity index 100% rename from src/Demo/Graphics/PanText.CC rename to src/Demo/Graphics/PanText.ZC diff --git a/src/Demo/Graphics/Pick.CC b/src/Demo/Graphics/Pick.ZC similarity index 100% rename from src/Demo/Graphics/Pick.CC rename to src/Demo/Graphics/Pick.ZC diff --git a/src/Demo/Graphics/Pick3D.CC b/src/Demo/Graphics/Pick3D.ZC similarity index 100% rename from src/Demo/Graphics/Pick3D.CC rename to src/Demo/Graphics/Pick3D.ZC diff --git a/src/Demo/Graphics/PoleZeros.CC b/src/Demo/Graphics/PoleZeros.ZC similarity index 100% rename from src/Demo/Graphics/PoleZeros.CC rename to src/Demo/Graphics/PoleZeros.ZC diff --git a/src/Demo/Graphics/PredatorPrey.CC b/src/Demo/Graphics/PredatorPrey.ZC similarity index 100% rename from src/Demo/Graphics/PredatorPrey.CC rename to src/Demo/Graphics/PredatorPrey.ZC diff --git a/src/Demo/Graphics/RotateTank.CC b/src/Demo/Graphics/RotateTank.ZC similarity index 100% rename from src/Demo/Graphics/RotateTank.CC rename to src/Demo/Graphics/RotateTank.ZC diff --git a/src/Demo/Graphics/ScreenCapture.CC b/src/Demo/Graphics/ScreenCapture.ZC similarity index 80% rename from src/Demo/Graphics/ScreenCapture.CC rename to src/Demo/Graphics/ScreenCapture.ZC index 1491fbcf..32771538 100755 --- a/src/Demo/Graphics/ScreenCapture.CC +++ b/src/Demo/Graphics/ScreenCapture.ZC @@ -1,4 +1,4 @@ -//See $LK,"::/Demo/Games/Stadium/StadiumGen.CC"$. +//See $LK,"::/Demo/Games/Stadium/StadiumGen.ZC"$. U0 Main() { diff --git a/src/Demo/Graphics/ScrollBars.CC b/src/Demo/Graphics/ScrollBars.ZC similarity index 100% rename from src/Demo/Graphics/ScrollBars.CC rename to src/Demo/Graphics/ScrollBars.ZC diff --git a/src/Demo/Graphics/Shading.CC b/src/Demo/Graphics/Shading.ZC similarity index 99% rename from src/Demo/Graphics/Shading.CC rename to src/Demo/Graphics/Shading.ZC index 4c58d9b3..bb97205c 100755 --- a/src/Demo/Graphics/Shading.CC +++ b/src/Demo/Graphics/Shading.ZC @@ -150,7 +150,7 @@ U0 DrawIt(CTask *task, CDC *dc) } } -//See $LK,"::/Demo/Graphics/SpritePlot3D.CC"$. +//See $LK,"::/Demo/Graphics/SpritePlot3D.ZC"$. //for a CSprite example. //See $LK,"SpriteMeshEd",A="MN:SpriteMeshEd"$() for a fancy example. diff --git a/src/Demo/Graphics/Shadow.CC b/src/Demo/Graphics/Shadow.ZC similarity index 100% rename from src/Demo/Graphics/Shadow.CC rename to src/Demo/Graphics/Shadow.ZC diff --git a/src/Demo/Graphics/Slider.CC b/src/Demo/Graphics/Slider.ZC similarity index 100% rename from src/Demo/Graphics/Slider.CC rename to src/Demo/Graphics/Slider.ZC diff --git a/src/Demo/Graphics/Speedline.CC b/src/Demo/Graphics/Speedline.ZC similarity index 100% rename from src/Demo/Graphics/Speedline.CC rename to src/Demo/Graphics/Speedline.ZC diff --git a/src/Demo/Graphics/SpritePlot.CC b/src/Demo/Graphics/SpritePlot.ZC similarity index 100% rename from src/Demo/Graphics/SpritePlot.CC rename to src/Demo/Graphics/SpritePlot.ZC diff --git a/src/Demo/Graphics/SpritePlot3D.CC b/src/Demo/Graphics/SpritePlot3D.ZC similarity index 100% rename from src/Demo/Graphics/SpritePlot3D.CC rename to src/Demo/Graphics/SpritePlot3D.ZC diff --git a/src/Demo/Graphics/SpritePut.CC b/src/Demo/Graphics/SpritePut.ZC similarity index 99% rename from src/Demo/Graphics/SpritePut.CC rename to src/Demo/Graphics/SpritePut.ZC index 733bcf13f8b002953e59fd7e828f61420a4549c1..b6587ca0c9153294f3848d8a9bed416aad675eb0 100755 GIT binary patch delta 14 WcmX?ni1F|t#tDs#Q5%~MCIA35mj=xM delta 14 WcmX?ni1F|t#tDs#&KsK!CIA35BnGws diff --git a/src/Demo/Graphics/SpritePutExt.CC b/src/Demo/Graphics/SpritePutExt.ZC similarity index 84% rename from src/Demo/Graphics/SpritePutExt.CC rename to src/Demo/Graphics/SpritePutExt.ZC index 9ceed402..6856ecd2 100755 --- a/src/Demo/Graphics/SpritePutExt.CC +++ b/src/Demo/Graphics/SpritePutExt.ZC @@ -1,6 +1,6 @@ /*If you press you will see this: -$$IB,"<1>",BI=1,BP="::/Demo/Graphics/SpritePut.CC,2"$$ +$$IB,"<1>",BI=1,BP="::/Demo/Graphics/SpritePut.ZC,2"$$ That imports an external sprite. It's called a $LK,"DOCEF_BIN_PTR_LINK",A="MN:DOCEF_BIN_PTR_LINK"$. See $LK,"BP=\"\"",A="FF:::/Doc/DolDocOverview.DD,BP=\"\""$. @@ -20,7 +20,7 @@ U0 SpritePutExt() for (i = 0; i < 3; i++) { "US Map:"; - Sprite($IB,"<1>",BI=1,BP="::/Demo/Graphics/SpritePut.CC,2"$); + Sprite($IB,"<1>",BI=1,BP="::/Demo/Graphics/SpritePut.ZC,2"$); "%h12c", '\n'; //"h" is a secondary arg. $LK,"Print",A="FI:::/Doc/Print.DD"$ 12 newline chars. } } diff --git a/src/Demo/Graphics/SpriteRaw.CC b/src/Demo/Graphics/SpriteRaw.ZC similarity index 100% rename from src/Demo/Graphics/SpriteRaw.CC rename to src/Demo/Graphics/SpriteRaw.ZC diff --git a/src/Demo/Graphics/SpriteText.CC b/src/Demo/Graphics/SpriteText.ZC similarity index 100% rename from src/Demo/Graphics/SpriteText.CC rename to src/Demo/Graphics/SpriteText.ZC diff --git a/src/Demo/Graphics/SunMoon.CC b/src/Demo/Graphics/SunMoon.ZC similarity index 100% rename from src/Demo/Graphics/SunMoon.CC rename to src/Demo/Graphics/SunMoon.ZC diff --git a/src/Demo/Graphics/Symmetry.CC b/src/Demo/Graphics/Symmetry.ZC similarity index 100% rename from src/Demo/Graphics/Symmetry.CC rename to src/Demo/Graphics/Symmetry.ZC diff --git a/src/Demo/Graphics/Transform.CC b/src/Demo/Graphics/Transform.ZC similarity index 100% rename from src/Demo/Graphics/Transform.CC rename to src/Demo/Graphics/Transform.ZC diff --git a/src/Demo/Graphics/WallPaperCtrl.CC b/src/Demo/Graphics/WallPaperCtrl.ZC similarity index 97% rename from src/Demo/Graphics/WallPaperCtrl.CC rename to src/Demo/Graphics/WallPaperCtrl.ZC index 19620259..cfea2ce4 100755 --- a/src/Demo/Graphics/WallPaperCtrl.CC +++ b/src/Demo/Graphics/WallPaperCtrl.ZC @@ -5,8 +5,8 @@ This is an advanced demo that shows that you can place ctrls on the wall paper. -See $LK,"::/Demo/Graphics/Slider.CC"$ -and $LK,"::/Demo/Graphics/WallPaperFish.CC"$ +See $LK,"::/Demo/Graphics/Slider.ZC"$ +and $LK,"::/Demo/Graphics/WallPaperFish.ZC"$ before messing with this program. It must be "System Included". diff --git a/src/Demo/Graphics/WallPaperFish.CC b/src/Demo/Graphics/WallPaperFish.ZC similarity index 100% rename from src/Demo/Graphics/WallPaperFish.CC rename to src/Demo/Graphics/WallPaperFish.ZC diff --git a/src/Demo/Graphics/WallPaperStars.CC b/src/Demo/Graphics/WallPaperStars.ZC similarity index 100% rename from src/Demo/Graphics/WallPaperStars.CC rename to src/Demo/Graphics/WallPaperStars.ZC diff --git a/src/Demo/Graphics/WinZBuf.CC b/src/Demo/Graphics/WinZBuf.ZC similarity index 100% rename from src/Demo/Graphics/WinZBuf.CC rename to src/Demo/Graphics/WinZBuf.ZC diff --git a/src/Demo/InFile/InPopUp.CC b/src/Demo/InFile/InPopUp.ZC similarity index 100% rename from src/Demo/InFile/InPopUp.CC rename to src/Demo/InFile/InPopUp.ZC diff --git a/src/Demo/InFile/InSetIP.CC b/src/Demo/InFile/InSetIP.ZC similarity index 100% rename from src/Demo/InFile/InSetIP.CC rename to src/Demo/InFile/InSetIP.ZC diff --git a/src/Demo/KeyBitMap.CC b/src/Demo/KeyBitMap.ZC similarity index 100% rename from src/Demo/KeyBitMap.CC rename to src/Demo/KeyBitMap.ZC diff --git a/src/Demo/LastClass.CC b/src/Demo/LastClass.ZC similarity index 92% rename from src/Demo/LastClass.CC rename to src/Demo/LastClass.ZC index 6a21f85f..bddb1fd1 100755 --- a/src/Demo/LastClass.CC +++ b/src/Demo/LastClass.ZC @@ -32,4 +32,4 @@ PressAKey; ClassRep(Fs); -//See also $LK,"DocForm",A="MN:DocForm"$(), $LK,"::/Demo/Disk/BlkDevRep.CC"$ and $LK,"::/Demo/ClassMeta.CC"$. +//See also $LK,"DocForm",A="MN:DocForm"$(), $LK,"::/Demo/Disk/BlkDevRep.ZC"$ and $LK,"::/Demo/ClassMeta.ZC"$. diff --git a/src/Demo/Lectures/64BitAsmQuiz.DD b/src/Demo/Lectures/64BitAsmQuiz.DD index 1d8c2f24..a0bdb7f7 100755 --- a/src/Demo/Lectures/64BitAsmQuiz.DD +++ b/src/Demo/Lectures/64BitAsmQuiz.DD @@ -76,7 +76,7 @@ ANSWERS: 8) To call a subroutine farther than 2Gig away, you put the address into RAX, then CALL RAX. -9) CALL REL32 is significantly faster. See $LK,"::/Demo/Lectures/InterruptDemo.CC"$. +9) CALL REL32 is significantly faster. See $LK,"::/Demo/Lectures/InterruptDemo.ZC"$. 10) IN or OUT instructions happen at a fixed speed based on the original ISA bus clock. diff --git a/src/Demo/Lectures/AndNotMod.CC b/src/Demo/Lectures/AndNotMod.ZC similarity index 100% rename from src/Demo/Lectures/AndNotMod.CC rename to src/Demo/Lectures/AndNotMod.ZC diff --git a/src/Demo/Lectures/FixedPoint.CC b/src/Demo/Lectures/FixedPoint.ZC similarity index 95% rename from src/Demo/Lectures/FixedPoint.CC rename to src/Demo/Lectures/FixedPoint.ZC index 28a72b69..35599d59 100755 --- a/src/Demo/Lectures/FixedPoint.CC +++ b/src/Demo/Lectures/FixedPoint.ZC @@ -12,7 +12,7 @@ and the ZealC compiler is poor with floats. Terry often used 64-bit ints with upper 32-bits as int and lower 32-bits as fraction. -See $LK,"::/Demo/SubIntAccess.CC"$ for how +See $LK,"::/Demo/SubIntAccess.ZC"$ for how to access upper or lower 32-bits. For a complete list of nonstandard compiler @@ -81,7 +81,7 @@ CPURep; Main; DoIt2; -//See $LK,"::/Demo/Lectures/FixedPointAdvanced.CC"$ +//See $LK,"::/Demo/Lectures/FixedPointAdvanced.ZC"$ /*Program Output$HL,0$$WW+H,1$$FD,1$ diff --git a/src/Demo/Lectures/FixedPointAdvanced.CC b/src/Demo/Lectures/FixedPointAdvanced.ZC similarity index 98% rename from src/Demo/Lectures/FixedPointAdvanced.CC rename to src/Demo/Lectures/FixedPointAdvanced.ZC index f481a783..277d01a9 100755 --- a/src/Demo/Lectures/FixedPointAdvanced.CC +++ b/src/Demo/Lectures/FixedPointAdvanced.ZC @@ -12,7 +12,7 @@ and the ZealC compiler is poor with floats. Terry often use 64-bit ints with upper 32-bits as int and lower 32-bits as fraction. -See $LK,"::/Demo/SubIntAccess.CC"$ for how +See $LK,"::/Demo/SubIntAccess.ZC"$ for how to access upper or lower 32-bits. */ diff --git a/src/Demo/Lectures/InterruptDemo.CC b/src/Demo/Lectures/InterruptDemo.ZC similarity index 100% rename from src/Demo/Lectures/InterruptDemo.CC rename to src/Demo/Lectures/InterruptDemo.ZC diff --git a/src/Demo/Lectures/MiniCompiler.CC b/src/Demo/Lectures/MiniCompiler.ZC similarity index 94% rename from src/Demo/Lectures/MiniCompiler.CC rename to src/Demo/Lectures/MiniCompiler.ZC index 6191eb71..8fc91e70 100755 --- a/src/Demo/Lectures/MiniCompiler.CC +++ b/src/Demo/Lectures/MiniCompiler.ZC @@ -4,9 +4,9 @@ $ID,2$The mini compiler is like the main compiler, except the main compiler's le The main compiler generates $LK,"Intermediate Code",A="FF:::/Compiler/CompilerA.HH,IC_END"$ at the parser stage. See $LK,"ParseExpression",A="MN:ParseExpression"$(), $LK,"ParseStatement",A="MN:ParseStatement"$(). -The main compiler optimizes See $LK,"Intermediate Code Attributes",A="MN:intermediate_code_table"$, $LK,"Combining Consts",A="FF:::/Compiler/OptPass012.CC,case IC_MUL"$, $LK,"Choosing Reg Vars",A="FF:::/Compiler/OptPass3.CC,cmp.num_reg_vars"$. Use $LK,"PassTrace",A="MN:PassTrace"$() to see the optimization stages. +The main compiler optimizes See $LK,"Intermediate Code Attributes",A="MN:intermediate_code_table"$, $LK,"Combining Consts",A="FF:::/Compiler/OptPass012.ZC,case IC_MUL"$, $LK,"Choosing Reg Vars",A="FF:::/Compiler/OptPass3.ZC,cmp.num_reg_vars"$. Use $LK,"PassTrace",A="MN:PassTrace"$() to see the optimization stages. -The main compiler makes machine code in the back end. See $LK,"IC Struct",A="MN:CIntermediateCode"$, $LK,"COCCompile",A="MN:COCCompile"$ and $LK,"OptPass789A",A="FF:::/Compiler/OptPass789A.CC,IC_MUL"$(), $LK,"BackEnd",A="FF:::/Compiler/BackA.CC,ICMul"$. Set $LK,"Trace",A="MN:Trace"$(ON) to see the output of the backend. +The main compiler makes machine code in the back end. See $LK,"IC Struct",A="MN:CIntermediateCode"$, $LK,"COCCompile",A="MN:COCCompile"$ and $LK,"OptPass789A",A="FF:::/Compiler/OptPass789A.ZC,IC_MUL"$(), $LK,"BackEnd",A="FF:::/Compiler/BackA.ZC,ICMul"$. Set $LK,"Trace",A="MN:Trace"$(ON) to see the output of the backend. $ID,-2$ $TR-C,"Mini Compiler"$ $ID,2$For this mini compiler, some things you should know about 64-bit asm: @@ -249,8 +249,8 @@ U0 Main() throw; "$$RED$$This code is not efficient, but the compiler is simple.$$FG$$\n"; Un(code, dst - code); //Unassemble the code we created. -//$LK,"Call",A="MN:Call"$() is a function. See $LK,"_CALL",A="FF:::/Kernel/KUtils.CC,_CALL"$:: - //See also $LK,"CallInd",A="MN:CallInd"$(). See $LK,"_CALL_IND",A="FF:::/Kernel/KUtils.CC,_CALL_IND"$:: +//$LK,"Call",A="MN:Call"$() is a function. See $LK,"_CALL",A="FF:::/Kernel/KUtils.ZC,_CALL"$:: + //See also $LK,"CallInd",A="MN:CallInd"$(). See $LK,"_CALL_IND",A="FF:::/Kernel/KUtils.ZC,_CALL_IND"$:: "$$LTBLUE$$Answer:%d$$FG$$\n", Call(code); } catch diff --git a/src/Demo/Lectures/MiniGrLib.CC b/src/Demo/Lectures/MiniGrLib.ZC similarity index 100% rename from src/Demo/Lectures/MiniGrLib.CC rename to src/Demo/Lectures/MiniGrLib.ZC diff --git a/src/Demo/Lectures/NegDisp.CC b/src/Demo/Lectures/NegDisp.ZC similarity index 100% rename from src/Demo/Lectures/NegDisp.CC rename to src/Demo/Lectures/NegDisp.ZC diff --git a/src/Demo/Lectures/Optimization.CC b/src/Demo/Lectures/Optimization.ZC similarity index 100% rename from src/Demo/Lectures/Optimization.CC rename to src/Demo/Lectures/Optimization.ZC diff --git a/src/Demo/Lectures/PCIInterrupts.CC b/src/Demo/Lectures/PCIInterrupts.ZC similarity index 100% rename from src/Demo/Lectures/PCIInterrupts.CC rename to src/Demo/Lectures/PCIInterrupts.ZC diff --git a/src/Demo/Lectures/Ring3.CC b/src/Demo/Lectures/Ring3.ZC similarity index 100% rename from src/Demo/Lectures/Ring3.CC rename to src/Demo/Lectures/Ring3.ZC diff --git a/src/Demo/MagicPairs.CC b/src/Demo/MagicPairs.ZC similarity index 100% rename from src/Demo/MagicPairs.CC rename to src/Demo/MagicPairs.ZC diff --git a/src/Demo/MemDemo.CC b/src/Demo/MemDemo.ZC similarity index 100% rename from src/Demo/MemDemo.CC rename to src/Demo/MemDemo.ZC diff --git a/src/Demo/MessageLoop.CC b/src/Demo/MessageLoop.ZC similarity index 100% rename from src/Demo/MessageLoop.CC rename to src/Demo/MessageLoop.ZC diff --git a/src/Demo/MultiCore/Interrupts.CC b/src/Demo/MultiCore/Interrupts.ZC similarity index 100% rename from src/Demo/MultiCore/Interrupts.CC rename to src/Demo/MultiCore/Interrupts.ZC diff --git a/src/Demo/MultiCore/LoadTest.CC b/src/Demo/MultiCore/LoadTest.ZC similarity index 93% rename from src/Demo/MultiCore/LoadTest.CC rename to src/Demo/MultiCore/LoadTest.ZC index 0110cc04..6efee43a 100755 --- a/src/Demo/MultiCore/LoadTest.CC +++ b/src/Demo/MultiCore/LoadTest.ZC @@ -16,7 +16,7 @@ U0 Job2(I64) {//Log a file while (!app_done) { - SysLog("%F", "::/Demo/MultiCore/LoadTest.CC"); + SysLog("%F", "::/Demo/MultiCore/LoadTest.ZC"); Yield; } lock {app_done_ack--;} diff --git a/src/Demo/MultiCore/Lock.CC b/src/Demo/MultiCore/Lock.ZC similarity index 100% rename from src/Demo/MultiCore/Lock.CC rename to src/Demo/MultiCore/Lock.ZC diff --git a/src/Demo/MultiCore/MPAdd.CC b/src/Demo/MultiCore/MPAdd.ZC similarity index 100% rename from src/Demo/MultiCore/MPAdd.CC rename to src/Demo/MultiCore/MPAdd.ZC diff --git a/src/Demo/MultiCore/MPPrint.CC b/src/Demo/MultiCore/MPPrint.ZC similarity index 100% rename from src/Demo/MultiCore/MPPrint.CC rename to src/Demo/MultiCore/MPPrint.ZC diff --git a/src/Demo/MultiCore/MPRadix.CC b/src/Demo/MultiCore/MPRadix.ZC similarity index 100% rename from src/Demo/MultiCore/MPRadix.CC rename to src/Demo/MultiCore/MPRadix.ZC diff --git a/src/Demo/MultiCore/Palindrome.CC b/src/Demo/MultiCore/Palindrome.ZC similarity index 100% rename from src/Demo/MultiCore/Palindrome.CC rename to src/Demo/MultiCore/Palindrome.ZC diff --git a/src/Demo/MultiCore/Primes.CC b/src/Demo/MultiCore/Primes.ZC similarity index 100% rename from src/Demo/MultiCore/Primes.CC rename to src/Demo/MultiCore/Primes.ZC diff --git a/src/Demo/NullCase.CC b/src/Demo/NullCase.ZC similarity index 100% rename from src/Demo/NullCase.CC rename to src/Demo/NullCase.ZC diff --git a/src/Demo/OnceDemo.CC b/src/Demo/OnceDemo.ZC similarity index 100% rename from src/Demo/OnceDemo.CC rename to src/Demo/OnceDemo.ZC diff --git a/src/Demo/ParenWarn.CC b/src/Demo/ParenWarn.ZC similarity index 100% rename from src/Demo/ParenWarn.CC rename to src/Demo/ParenWarn.ZC diff --git a/src/Demo/PhoneNumWords.CC b/src/Demo/PhoneNumWords.ZC similarity index 100% rename from src/Demo/PhoneNumWords.CC rename to src/Demo/PhoneNumWords.ZC diff --git a/src/Demo/Print.CC b/src/Demo/Print.ZC similarity index 100% rename from src/Demo/Print.CC rename to src/Demo/Print.ZC diff --git a/src/Demo/Progress.CC b/src/Demo/Progress.ZC similarity index 100% rename from src/Demo/Progress.CC rename to src/Demo/Progress.ZC diff --git a/src/Demo/Prompt.CC b/src/Demo/Prompt.ZC similarity index 100% rename from src/Demo/Prompt.CC rename to src/Demo/Prompt.ZC diff --git a/src/Demo/PullDownMenu.CC b/src/Demo/PullDownMenu.ZC similarity index 100% rename from src/Demo/PullDownMenu.CC rename to src/Demo/PullDownMenu.ZC diff --git a/src/Demo/RadixSort.CC b/src/Demo/RadixSort.ZC similarity index 100% rename from src/Demo/RadixSort.CC rename to src/Demo/RadixSort.ZC diff --git a/src/Demo/RandDemo.CC b/src/Demo/RandDemo.ZC similarity index 94% rename from src/Demo/RandDemo.CC rename to src/Demo/RandDemo.ZC index 87e5755d..bdee1a78 100755 --- a/src/Demo/RandDemo.CC +++ b/src/Demo/RandDemo.ZC @@ -22,7 +22,7 @@ U0 RandDemo() I64 i; "Seed(0) will do timer XORed random numbers. " - "A task starts with $LK,"Seed(0)",A="FF:::/Kernel/KTask.CC,Seed("$ by default.\n"; + "A task starts with $LK,"Seed(0)",A="FF:::/Kernel/KTask.ZC,Seed("$ by default.\n"; PressAKey; Seed; RandPts; diff --git a/src/Demo/RegistryDemo.CC b/src/Demo/RegistryDemo.ZC similarity index 95% rename from src/Demo/RegistryDemo.CC rename to src/Demo/RegistryDemo.ZC index ef751c27..554b1462 100755 --- a/src/Demo/RegistryDemo.CC +++ b/src/Demo/RegistryDemo.ZC @@ -1,4 +1,4 @@ -/*The ~/Registry.CC file is ZealC code. +/*The ~/Registry.ZC file is ZealC code. You can execute a tree branch of it. The System branch is executed in the System task boot phase. Normally, you will place variable declarations diff --git a/src/Demo/RevFileDemo/Rev.CC b/src/Demo/RevFileDemo/Rev.ZC similarity index 100% rename from src/Demo/RevFileDemo/Rev.CC rename to src/Demo/RevFileDemo/Rev.ZC diff --git a/src/Demo/ScreenCodes.CC b/src/Demo/ScreenCodes.ZC similarity index 83% rename from src/Demo/ScreenCodes.CC rename to src/Demo/ScreenCodes.ZC index d2084006..eb692efc 100755 --- a/src/Demo/ScreenCodes.CC +++ b/src/Demo/ScreenCodes.ZC @@ -1,8 +1,8 @@ /*See $LK,"TextBase Layer",A="HI:TextBase Layer"$ for the format of the U32 you pass to TextChar() -See $LK,"::/Doc/CharOverview.DD"$, $LK,"::/Demo/ExtChars.CC"$, -and $LK,"::/Demo/Graphics/FontEd.CC"$. +See $LK,"::/Doc/CharOverview.DD"$, $LK,"::/Demo/ExtChars.ZC"$, +and $LK,"::/Demo/Graphics/FontEd.ZC"$. Hold and press a 3 digit decimal number or press to enter extended characters. diff --git a/src/Demo/SortFileDemo/F64FileGen.CC b/src/Demo/SortFileDemo/F64FileGen.ZC similarity index 98% rename from src/Demo/SortFileDemo/F64FileGen.CC rename to src/Demo/SortFileDemo/F64FileGen.ZC index aaf7a824..6beb1dc1 100755 --- a/src/Demo/SortFileDemo/F64FileGen.CC +++ b/src/Demo/SortFileDemo/F64FileGen.ZC @@ -16,7 +16,7 @@ U0 F64FileGenTXT(U8 *filename, I64 n) F64FileGenTXT("~/DemoUnsortedF64.DD", 10); U0 F64FileGenDAT(U8 *filename, I64 n) -{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.CC"$ +{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.ZC"$ I64 i; F64 *a = MAlloc(n * sizeof(F64)); diff --git a/src/Demo/SortFileDemo/F64FileSort.CC b/src/Demo/SortFileDemo/F64FileSort.ZC similarity index 99% rename from src/Demo/SortFileDemo/F64FileSort.CC rename to src/Demo/SortFileDemo/F64FileSort.ZC index 43558223..aabbbea8 100755 --- a/src/Demo/SortFileDemo/F64FileSort.CC +++ b/src/Demo/SortFileDemo/F64FileSort.ZC @@ -49,7 +49,7 @@ Type("~/DemoUnsortedF64.DD"); Type("~/DemoSortedF64.DD"); U0 F64FileSortDAT(U8 *in_name, U8 *out_name) -{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.CC"$ +{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.ZC"$ I64 size; F64 *a = FileRead(in_name, &size); @@ -60,7 +60,7 @@ U0 F64FileSortDAT(U8 *in_name, U8 *out_name) F64FileSortDAT("~/DemoUnsortedF64.DATA", "~/DemoSortedF64.DATA"); U0 F64FileDumpDAT(U8 *in_name) -{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.CC"$ +{//$LK,"File/CFile",A="HI:File/CFile"$, $LK,"::/Demo/Disk/DataBase.ZC"$ I64 i, n, size; F64 *a = FileRead(in_name, &size); diff --git a/src/Demo/Sound/ASCIIOrgan.CC b/src/Demo/Sound/ASCIIOrgan.ZC similarity index 100% rename from src/Demo/Sound/ASCIIOrgan.CC rename to src/Demo/Sound/ASCIIOrgan.ZC diff --git a/src/Demo/Sound/MorseCode.CC b/src/Demo/Sound/MorseCode.ZC similarity index 100% rename from src/Demo/Sound/MorseCode.CC rename to src/Demo/Sound/MorseCode.ZC diff --git a/src/Demo/Sound/OhGreat.CC b/src/Demo/Sound/OhGreat.ZC similarity index 100% rename from src/Demo/Sound/OhGreat.CC rename to src/Demo/Sound/OhGreat.ZC diff --git a/src/Demo/Sound/WaterFowl.CC b/src/Demo/Sound/WaterFowl.ZC similarity index 100% rename from src/Demo/Sound/WaterFowl.CC rename to src/Demo/Sound/WaterFowl.ZC diff --git a/src/Demo/Spy.CC b/src/Demo/Spy.ZC similarity index 100% rename from src/Demo/Spy.CC rename to src/Demo/Spy.ZC diff --git a/src/Demo/StackGrow.CC b/src/Demo/StackGrow.ZC similarity index 100% rename from src/Demo/StackGrow.CC rename to src/Demo/StackGrow.ZC diff --git a/src/Demo/SubIntAccess.CC b/src/Demo/SubIntAccess.ZC similarity index 93% rename from src/Demo/SubIntAccess.CC rename to src/Demo/SubIntAccess.ZC index 17c028a0..831d41d5 100755 --- a/src/Demo/SubIntAccess.CC +++ b/src/Demo/SubIntAccess.ZC @@ -6,7 +6,7 @@ The versions with "i" are internal data types. Use "I64" instead of "U64i" and y Unfortunately, byte access causes the compiler to not use a register for the variable. -See $LK,"::/Demo/Lectures/FixedPoint.CC"$. +See $LK,"::/Demo/Lectures/FixedPoint.ZC"$. */ I64 q = 0xFEDCBA9876543210, q1; diff --git a/src/Demo/SubSwitch.CC b/src/Demo/SubSwitch.ZC similarity index 100% rename from src/Demo/SubSwitch.CC rename to src/Demo/SubSwitch.ZC diff --git a/src/Demo/SuggestSpelling.CC b/src/Demo/SuggestSpelling.ZC similarity index 100% rename from src/Demo/SuggestSpelling.CC rename to src/Demo/SuggestSpelling.ZC diff --git a/src/Demo/Templates/Game1.CC b/src/Demo/Templates/Game1.ZC similarity index 100% rename from src/Demo/Templates/Game1.CC rename to src/Demo/Templates/Game1.ZC diff --git a/src/Demo/Templates/Lex1.CC b/src/Demo/Templates/Lex1.ZC similarity index 100% rename from src/Demo/Templates/Lex1.CC rename to src/Demo/Templates/Lex1.ZC diff --git a/src/Demo/Templates/MultiCore1.CC b/src/Demo/Templates/MultiCore1.ZC similarity index 100% rename from src/Demo/Templates/MultiCore1.CC rename to src/Demo/Templates/MultiCore1.ZC diff --git a/src/Demo/Templates/ODE1.CC b/src/Demo/Templates/ODE1.ZC similarity index 100% rename from src/Demo/Templates/ODE1.CC rename to src/Demo/Templates/ODE1.ZC diff --git a/src/Demo/Templates/Registry1.CC b/src/Demo/Templates/Registry1.ZC similarity index 100% rename from src/Demo/Templates/Registry1.CC rename to src/Demo/Templates/Registry1.ZC diff --git a/src/Demo/Templates/Util1.CC b/src/Demo/Templates/Util1.ZC similarity index 100% rename from src/Demo/Templates/Util1.CC rename to src/Demo/Templates/Util1.ZC diff --git a/src/Demo/Templates/Util2.CC b/src/Demo/Templates/Util2.ZC similarity index 100% rename from src/Demo/Templates/Util2.CC rename to src/Demo/Templates/Util2.ZC diff --git a/src/Demo/TimeIns.CC b/src/Demo/TimeIns.ZC similarity index 100% rename from src/Demo/TimeIns.CC rename to src/Demo/TimeIns.ZC diff --git a/src/Demo/ToHtmlToTXTDemo/HtmlDirList.CC b/src/Demo/ToHtmlToTXTDemo/HtmlDirList.ZC similarity index 100% rename from src/Demo/ToHtmlToTXTDemo/HtmlDirList.CC rename to src/Demo/ToHtmlToTXTDemo/HtmlDirList.ZC diff --git a/src/Demo/ToHtmlToTXTDemo/HtmlGen.CC b/src/Demo/ToHtmlToTXTDemo/HtmlGen.ZC similarity index 73% rename from src/Demo/ToHtmlToTXTDemo/HtmlGen.CC rename to src/Demo/ToHtmlToTXTDemo/HtmlGen.ZC index 76c67c08..f6115eb1 100755 --- a/src/Demo/ToHtmlToTXTDemo/HtmlGen.CC +++ b/src/Demo/ToHtmlToTXTDemo/HtmlGen.ZC @@ -4,14 +4,14 @@ an html document named "OutPage.html". Notice that an entry like $$TX,"GOOGLE",HTML="http://www.google.com"$$ will be converted to text in the html with an html link. -Terry cheated by hardcoding $LK,"www.templeos.org",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.CC,www.templeos.org"$ as the website +Terry cheated by hardcoding $LK,"www.templeos.org",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.ZC,www.templeos.org"$ as the website for $LK,"ZealOS Links",A="MN:LK_FILE"$. Why don't you copy -$LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$ to your /Home directory +$LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$ to your /Home directory and modify it? You are welcome to link to http://www.templeos.org if you want file that come on the ZealOS distribution. -You can pass html meta data as args to $LK,"ToHtml",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.CC,ToHtml"$(). +You can pass html meta data as args to $LK,"ToHtml",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.ZC,ToHtml"$(). */ Cd(__DIR__);; diff --git a/src/Demo/ToHtmlToTXTDemo/TXTGen.CC b/src/Demo/ToHtmlToTXTDemo/TXTGen.ZC similarity index 100% rename from src/Demo/ToHtmlToTXTDemo/TXTGen.CC rename to src/Demo/ToHtmlToTXTDemo/TXTGen.ZC diff --git a/src/Demo/ToHtmlToTXTDemo/ToHtml.CC b/src/Demo/ToHtmlToTXTDemo/ToHtml.ZC similarity index 99% rename from src/Demo/ToHtmlToTXTDemo/ToHtml.CC rename to src/Demo/ToHtmlToTXTDemo/ToHtml.ZC index 9d598633..fca5418f 100755 --- a/src/Demo/ToHtmlToTXTDemo/ToHtml.CC +++ b/src/Demo/ToHtmlToTXTDemo/ToHtml.ZC @@ -408,7 +408,7 @@ public U0 ToHtml(U8 *_in_name, U8 *_out_name=NULL, U8 *html_header=NULL, SettingsPush; //See $LK,"SettingsPush",A="MN:SettingsPush"$ WinHorz(1, width - 2); //Sets doc width for word wrap. - in_name=ExtDefault(_in_name, "CC"); + in_name=ExtDefault(_in_name, "ZC"); if (_out_name) out_name = ExtDefault(_out_name, "html"); else diff --git a/src/Demo/WebLogDemo/WebLogRep.CC b/src/Demo/WebLogDemo/WebLogRep.ZC similarity index 100% rename from src/Demo/WebLogDemo/WebLogRep.CC rename to src/Demo/WebLogDemo/WebLogRep.ZC diff --git a/src/Demo/WebLogDemo/WebLogScramble.CC b/src/Demo/WebLogDemo/WebLogScramble.ZC similarity index 100% rename from src/Demo/WebLogDemo/WebLogScramble.CC rename to src/Demo/WebLogDemo/WebLogScramble.ZC diff --git a/src/Demo/WordSearch.CC b/src/Demo/WordSearch.ZC similarity index 98% rename from src/Demo/WordSearch.CC rename to src/Demo/WordSearch.ZC index 6d5c65fd..aaa3b151 100755 --- a/src/Demo/WordSearch.CC +++ b/src/Demo/WordSearch.ZC @@ -1,6 +1,6 @@ //Simple and fancy way of searching -//See ::/Apps/Vocabulary/VocabQuiz.CC +//See ::/Apps/Vocabulary/VocabQuiz.ZC //for another example of dictionary usage. #define ROWS_NUM 20 diff --git a/src/Doc/Asm.DD b/src/Doc/Asm.DD index fcaedc08..2f7f8cb6 100755 --- a/src/Doc/Asm.DD +++ b/src/Doc/Asm.DD @@ -44,4 +44,4 @@ $FG,2$ORG$FG$ $FG,4$num$FG$ $FG,2$BINFILE$FG,4$ "FileName.BIN"$FG$; -See $LK,"Assembly Language",A="FF:::/Doc/GuideLines.DD,Assembly Language"$, $LK,"::/Demo/Asm/AsmAndC1.CC"$, $LK,"::/Demo/Asm/AsmAndC2.CC"$ and $LK,"::/Demo/Asm/AsmAndC3.CC"$. +See $LK,"Assembly Language",A="FF:::/Doc/GuideLines.DD,Assembly Language"$, $LK,"::/Demo/Asm/AsmAndC1.ZC"$, $LK,"::/Demo/Asm/AsmAndC2.ZC"$ and $LK,"::/Demo/Asm/AsmAndC3.ZC"$. diff --git a/src/Doc/AutoComplete.DD b/src/Doc/AutoComplete.DD index 486032ee..1d25f324 100755 --- a/src/Doc/AutoComplete.DD +++ b/src/Doc/AutoComplete.DD @@ -1,4 +1,4 @@ -$FG,2$$WW,1$AutoComplete$FG$ is the $FG,7$LTGRAY$FG$ window on the right of the screen. $LK,"ACInit",A="MN:ACInit"$() collects words from all text files in subdirectories. Normally, the call to $LK,"ACInit",A="MN:ACInit"$() is in $LK,"HomeSys.CC",A="FF:~/HomeSys.CC,ACInit"$. It provides auto-complete for typing, jump-to-code and jump-to-dictionary functionality. +$FG,2$$WW,1$AutoComplete$FG$ is the $FG,7$LTGRAY$FG$ window on the right of the screen. $LK,"ACInit",A="MN:ACInit"$() collects words from all text files in subdirectories. Normally, the call to $LK,"ACInit",A="MN:ACInit"$() is in $LK,"HomeSys.ZC",A="FF:~/HomeSys.ZC,ACInit"$. It provides auto-complete for typing, jump-to-code and jump-to-dictionary functionality. $FG,2$$FG$ Closes the $FG,7$LTGRAY$FG$ AutoComplete window. $FG,2$$FG$ Opens the $FG,7$LTGRAY$FG$ AutoComplete window. @@ -16,4 +16,4 @@ $FG,2$$FG$ Autocompletes the 1st dictionary word in the window. $FG,2$$FG$ Autocompletes the 2nd dictionary word in the window. $FG,2$$FG$ Autocompletes the n-th dictionary word in the window. -If you have the raw Project Gutenberg dictionary file, you can generate the ZealOS processed dictionary files with the stand-alone program $LK,"::/System/AutoComplete/ACDictGen.CC"$. +If you have the raw Project Gutenberg dictionary file, you can generate the ZealOS processed dictionary files with the stand-alone program $LK,"::/System/AutoComplete/ACDictGen.ZC"$. diff --git a/src/Doc/BlkChain.DD b/src/Doc/BlkChain.DD index 5e82c9ca..309ab959 100755 --- a/src/Doc/BlkChain.DD +++ b/src/Doc/BlkChain.DD @@ -10,7 +10,7 @@ When doing large, whole-file operations, immediately memory fragmentation is a s The $LK,"DolDoc",A="FI:::/Doc/DolDoc.DD"$ format cannot have text tacked onto the end, since binary data is at the end. -Terry didn't want to spoil fun, so of course offered a way to get awesome performance that is, ironically, superior. $LK,"FBlkRead",A="MN:FBlkRead"$() and $LK,"FBlkWrite",A="MN:FBlkWrite"$() allow you to read a block offset from the start of a file. Since files are all contiguous, this is incredibly efficient. You just have to declare the desired file size when you create it with $LK,"FOpen",A="MN:FOpen"$() and cannot change it. See $LK,"::/Demo/Disk/DataBase.CC"$. +Terry didn't want to spoil fun, so of course offered a way to get awesome performance that is, ironically, superior. $LK,"FBlkRead",A="MN:FBlkRead"$() and $LK,"FBlkWrite",A="MN:FBlkWrite"$() allow you to read a block offset from the start of a file. Since files are all contiguous, this is incredibly efficient. You just have to declare the desired file size when you create it with $LK,"FOpen",A="MN:FOpen"$() and cannot change it. See $LK,"::/Demo/Disk/DataBase.ZC"$. If you like, you are encouraged to to do raw $LK,"BlkRead",A="MN:BlkRead"$() and $LK,"BlkWrite",A="MN:BlkWrite"$() directly on a drive. Just get a pointer to a $LK,"CDrive",A="MN:CDrive"$ with $LK,"Letter2Drive",A="MN:Letter2Drive"$() and you are on your way! Your computer is supposed to be a fun toy! You can make an entire partition used for a database, or invent a file system. diff --git a/src/Doc/Boot.DD b/src/Doc/Boot.DD index 7a8cd79dac9bd2a015d08a623eb2caea8fe18771..775a2481d6e6485b868f6cd8ea60b2eb09dae468 100755 GIT binary patch delta 160 zcmX@EbzEx$CmUnbWG=Q;AX&hs03;`}X@S}Dte$zrdQp=fur-7E5|eA#`GBl$_Gr;4 zXC)OqE-n=xZyhD4{QMGM4;P@y01kO3ASJ_L3{)1tp$H_4I84E8s9~GWaM&^e1q#?? eSioAexbz`hb`KY@b(?Fs%vczsHgDmZ%mx7C#VfP` delta 160 zcmX@EbzEx$CmW;lWG=Q;AX&hs03;`}X@S}Dte$zrdd`y{ur-7E5|eA#`GBl$_GnRO zXC)OqE-n=xZyhD4{QMGM4;P@y01kO3ASJ_L3{)1tp$H_4I84E8s9~GWaM&^e1q#?? eSioAexbz`hb`KY@b(?Fs%vczmH*eva%mx5jAu0a= diff --git a/src/Doc/ChangeLog.DD b/src/Doc/ChangeLog.DD index 0aff8b2b..f77f71dd 100755 --- a/src/Doc/ChangeLog.DD +++ b/src/Doc/ChangeLog.DD @@ -1,4 +1,16 @@ $WW,1$$FG,5$$TX+CX,"ChangeLog"$$FG$ + +$IV,1$----12/11/21 05:57:44----$IV,0$ +* Raised version number to 1.07. +* $UL,1$Rename CosmiC -> ZealC.$UL,0$ +* $UL$Renamed all files from .CC -> .ZC to reflect language name change.$UL,0$ +* $LK,"R",A="MN:R"$("HOLYC_TYPECAST", "POSTFIX_TYPECAST", "-i"); +* $LK,"R",A="MN:R"$("CosmiC", "ZealC", "-i"); +* Rename Doc/CosmiC.DD to $LK+PU,"Doc/ZealC.DD",A="FI:::/Doc/ZealC.DD"$. +* $LK,"R",A="MN:R"$("\"CC\", "\"ZC\""); +* $LK,"R",A="MN:R"$(".CC", ".ZC", "-i"); +* $LK,"FR",A="MN:FR"$(".CC", ".ZC"); + $IV,1$----12/09/21 03:21:03----$IV,0$ * Revert 440Hz 'A'. @@ -51,7 +63,7 @@ $IV,1$----10/07/21 18:06:15----$IV,0$ * Fixed Std Font characters after char 128. * Added links to ZealOS-specific applications in PersonalMenu. * Removed all files from ::/Downloads. -* Started initial work integrating SSE instructions into assembler. $MA-X+PU,"See changes here.",LM="Find(\"XMM\", \"::/Compiler/OpCodes.DD\", \"-i\");\"\n\n\";Find(\"XMM\", \"::/Compiler/Asm.CC\", \"-i\");\"\n\";Find(\" == 128\", \"::/Compiler/UAsm.CC\", \"-i\");\"\n\";Find(\"XMM\", \"::/Compiler/UAsm.CC\", \"-i\");\"\n\";Find(\"size_arg_mask[16]\", \"::/Compiler/AsmInit.CC\", \"-i\");\"\n\";Find(\"size_arg_mask[0] = 0xF\", \"::/Compiler/AsmInit.CC\", \"-i\");\"\n\";Find(\"arg_mask[17\", \"::/Kernel/KernelA.HH\", \"-i\");\"\n\";Find(\"SSE\", \"::/Kernel/MultiProc.CC\", \"-i\");View;"$ Only added 2 arg opcodes and only added instructions <= 4 bytes. $TX+IV,"Current bugs"$: unassembling SSE instructions that use non-128-bit vars will incorrectly report U128, MOVHLPS and MOVLHPS 2nd operand is defined XMM128 to hack ModrM order but operands should be XMM XMM, due to MOVSD name clash we define opcode as MOVSD_SSE. $TX+IV,"TODO"$: add ZealC U128 and XMM register allocation support, find way to ensure 16-byte aligned stack to use aligned SSE instructions. +* Started initial work integrating SSE instructions into assembler. $MA-X+PU,"See changes here.",LM="Find(\"XMM\", \"::/Compiler/OpCodes.DD\", \"-i\");\"\n\n\";Find(\"XMM\", \"::/Compiler/Asm.CC\", \"-i\");\"\n\";Find(\" == 128\", \"::/Compiler/UAsm.CC\", \"-i\");\"\n\";Find(\"XMM\", \"::/Compiler/UAsm.CC\", \"-i\");\"\n\";Find(\"size_arg_mask[16]\", \"::/Compiler/AsmInit.CC\", \"-i\");\"\n\";Find(\"size_arg_mask[0] = 0xF\", \"::/Compiler/AsmInit.CC\", \"-i\");\"\n\";Find(\"arg_mask[17\", \"::/Kernel/KernelA.HH\", \"-i\");\"\n\";Find(\"SSE\", \"::/Kernel/MultiProc.CC\", \"-i\");View;"$ Only added 2 arg opcodes and only added instructions <= 4 bytes. $TX+IV,"Current bugs"$: unassembling SSE instructions that use non-128-bit vars will incorrectly report U128, MOVHLPS and MOVLHPS 2nd operand is defined XMM128 to hack ModrM order but operands should be XMM XMM, due to MOVSD name clash we define opcode as MOVSD_SSE. $TX+IV,"TODO"$: add U128 and XMM register allocation support, find way to ensure 16-byte aligned stack to use aligned SSE instructions. $IV,1$----09/21/21 23:35:00----$IV,0$ * Raised version number to 1.01. @@ -225,7 +237,7 @@ $IV,1$----06/28/21 06:20:21----$IV,0$ $IV,1$----06/24/21 01:01:06----$IV,0$ * Raised version number to ZenithOS 2.1. * Implemented PCI fall-back functions for when PCIBIOS is unsupported, to improve bare-metal support. -* Abstracted $LK+PU,"PCI functions",A="FI:::/Kernel/PCI.CC"$ out from $LK+PU,"PCIBIOS",A="FI:::/Kernel/PCIBIOS.CC"$ file. +* Abstracted $LK+PU,"PCI functions",A="FI:::/Kernel/PCI.ZC"$ out from $LK+PU,"PCIBIOS",A="FI:::/Kernel/PCIBIOS.ZC"$ file. $IV,1$----06/01/21 16:02:38----$IV,0$ $BK,1$* Raised version number to ZenithOS 2.0.$BK,0$ @@ -261,13 +273,13 @@ $IV,1$----06/04/20 18:01:46----$IV,0$ * Added $LK,"BIOSRep",A="MN:BIOSRep"$() as convenience function to view BIOS info from $LK,"SysRep",A="MN:SysRep"$(). $IV,1$----04/27/20 15:34:42----$IV,0$ -* Changed $LK+PU,"GrBitMap",A="FI:::/System/Gr/GrBitMap.CC"$ to use non-timer rand for drawing speed improvement on multicore. +* Changed $LK+PU,"GrBitMap",A="FI:::/System/Gr/GrBitMap.ZC"$ to use non-timer rand for drawing speed improvement on multicore. $IV,1$----04/21/20 18:54:47----$IV,0$ * Altered $LK+PU,"Tom Palettes",A="FF:::/System/Gr/GrPalette.CC,PaletteSetDark"$ for better visibility. $IV,1$----04/21/20 16:13:01----$IV,0$ -* Added start-up intro $LK+PU,"Splash",A="FI:::/System/ZSplash.CC"$ as a PopUp in $LK+PU,"Once",A="FF:::/HomeSys.CC,PopUp"$, after performing a full boot (excludes soft reboots). +* Added start-up intro $LK+PU,"Splash",A="FI:::/System/ZSplash.ZC"$ as a PopUp in $LK+PU,"Once",A="FF:::/HomeSys.CC,PopUp"$, after performing a full boot (excludes soft reboots). $IV,1$----04/13/20 13:48:15----$IV,0$ * Added $LK,"PIC_INIT",A="MN:PIC_INIT"$ and comments to $LK,"IntPICInit",A="MN:IntPICInit"$(). @@ -289,7 +301,7 @@ $IV,1$----04/10/20 07:44:08----$IV,0$ * $LK,"R",A="MN:R"$("PIT2", "$LK,"PIT_2",A="MN:PIT_2"$"); $IV,1$----04/09/20 19:33:16----$IV,0$ -* Added $LK,"Chess",A="FI:::/Demo/Games/Chess.CC"$ game from Sup1 disc. +* Added $LK,"Chess",A="FI:::/Demo/Games/Chess.ZC"$ game from Sup1 disc. * $LK,"R",A="MN:R"$("ScanFlags", "$LK,"FlagsScan",A="MN:FlagsScan"$"); * $LK,"R",A="MN:R"$("StrPrintFlags", "$LK,"FlagsStrPrint",A="MN:FlagsStrPrint"$"); * $LK,"R",A="MN:R"$("ScanMessage", "$LK,"MessageScan",A="MN:MessageScan"$"); @@ -304,7 +316,7 @@ $IV,1$----04/02/20 01:50:52----$IV,0$ * 'Fixed' $LK,"Varoom",A="FF:::/Demo/Games/Varoom.CC,kbd.down_bitmap"$ window lock up on exit. Brute-forcing zero, but somewhere $LK,"mp_not_done_flags",A="FF:::/Demo/Games/Varoom.CC,mp_not_done_flags"$ isn't getting cleared when shift-esc is entered with the new key implementation. $IV,1$----04/01/20 01:49:47----$IV,0$ -* Changed boat color in $LK,"Talons",A="FI:::/Demo/Games/Talons.CC"$ from black to brown. +* Changed boat color in $LK,"Talons",A="FI:::/Demo/Games/Talons.ZC"$ from black to brown. $IV,1$----04/01/20 01:42:55----$IV,0$ * Cleaned up $LK,"Varoom",A="FF:::/Demo/Games/Varoom.CC,kbd.down_bitmap"$ control fix some. Bug remains: run from Menu, ESC out, ESC again; a window locks up. @@ -352,7 +364,7 @@ $IV,1$----03/19/20 01:51:36----$IV,0$ * $LK,"R",A="MN:R"$("IC_SET_RFLAGS", "$LK,"IC_RFLAGS_SET",A="MN:IC_RFLAGS_SET"$"); * $LK,"R",A="MN:R"$("GetTSC", "$LK,"TSCGet",A="MN:TSCGet"$"); * $LK,"R",A="MN:R"$("GetS", "$LK,"StrNGet",A="MN:StrNGet"$"); -* Modified characters '_' and 'c' in $LK,"FontStd",A="FI:::/Kernel/FontStd.CC"$. +* Modified characters '_' and 'c' in $LK,"FontStd",A="FI:::/Kernel/FontStd.ZC"$. $IV,1$----03/16/20 14:44:00----$IV,0$ * $LK,"R",A="MN:R"$("GetStr", "$LK,"StrGet",A="MN:StrGet"$"); @@ -371,12 +383,12 @@ $IV,1$----02/23/20 23:59:37----$IV,0$ $IV,1$----02/23/20 02:36:28----$IV,0$ * $LK,"R",A="MN:R"$("err", "error"); -* Removed compression from kernel. Compress.CC, CArcCtrl, CArcCompress, ExpandBuf(), CompressBuf(), DCSF_COMPRESSED, etc. Updated $LK,"::/Demo/Disk/SerializeTree.CC",A="FI:::/Demo/Disk/SerializeTree.CC"$ to not use compression. +* Removed compression from kernel. Compress.CC, CArcCtrl, CArcCompress, ExpandBuf(), CompressBuf(), DCSF_COMPRESSED, etc. Updated $LK,"::/Demo/Disk/SerializeTree.ZC",A="FI:::/Demo/Disk/SerializeTree.ZC"$ to not use compression. * Removed RS_ATTR_COMPRESSED from $LK,"RedSea attributes",A="MN:RS_ATTR_READ_ONLY"$. * Refactored $LK,"FU flags",A="MN:FUf_RECURSE"$. Removed FUF_EXPAND, FUF_RISKY, and FUF_Z_OR_NOT_Z. $LK,"DocOptEntry",A="MN:DocOptEntry"$(), $LK,"Size",A="MN:Size"$(), $LK,"Size1",A="MN:Size1"$(), $LK,"SizeRep",A="MN:SizeRep"$(), and $LK,"SizeRep1",A="MN:SizeRep1"$() have been updated accordingly. * Removed IsDotZ(), ToggleZOrNotZ(). Cleaned up $LK,"FileRead",A="MN:FileRead"$(), $LK,"FileWrite",A="MN:FileWrite"$(), and $LK,"FileFind",A="MN:FileFind"$() accordingly. * Added XMM8-XMM15 to $LK,"OpCodes.DD",A="FF:::/Compiler/OpCodes.DD,XMM8"$. -* Added $LK,"::/Demo/Graphics/32BitColor.CC",A="FI:::/Demo/Graphics/32BitColor.CC"$. +* Added $LK,"::/Demo/Graphics/32BitColor.ZC",A="FI:::/Demo/Graphics/32BitColor.ZC"$. $IV,1$----02/22/20 20:04:00----$IV,0$ * Reduced $LK,"MEM_MIN_MEG",A="MN:MEM_MIN_MEG"$ to 256 MiB (VMWare users have to do less work). @@ -392,7 +404,7 @@ $IV,1$----02/21/20 17:30:17----$IV,0$ * Renamed BIOSTotalMem() -> $LK,"MemBIOSTotal",A="MN:MemBIOSTotal"$(), rewritten and commented for clarity, exported from kernel. Neat function. $IV,1$----02/20/20 17:40:10----$IV,0$ -* Replaced old standard font with new $LK,"FontStd",A="FI:::/Kernel/FontStd.CC"$. The auxilliary font is now the VGA ROM Font. +* Replaced old standard font with new $LK,"FontStd",A="FI:::/Kernel/FontStd.ZC"$. The auxilliary font is now the VGA ROM Font. * $UL,1$We now use 1 Tab (4 spaces wide) for indentation.$UL,0$ All spaces used for indentation have been converted to tabs. Header files are messy. $LK,"PCILookUpSingle",A="MN:PCILookUpSingle"$() was fixed according to this change. $LK,"EdCodeTools",A="MN:EdCodeTools"$ re-indentation feature needs to be updated. $IV,1$----02/19/20 21:46:17----$IV,0$ @@ -400,15 +412,15 @@ $BK,1$* Zenith 1.0 released.$BK,0$ * $LK,"GRScreenCaptureWrite",A="MN:GRScreenCaptureWrite"$() and $LK,"GRScreenCaptureRead",A="MN:GRScreenCaptureRead"$() are broken. $LK,"DCLoad",A="MN:DCLoad"$() and $LK,"DCSave",A="MN:DCSave"$() use DCF_COMPRESSED. It also saves the palette as $LK,"CBGR48",A="MN:CBGR48"$, which is a problem. * Updated $LK,"MemRep",A="MN:MemRep"$() to report on VBE variables. * Renamed VGAFlush() -> $LK,"LFBFlush",A="MN:LFBFlush"$(). -* Updated $LK,"Palette Demo",A="FI:::/Demo/Graphics/Palette.CC"$ to use current palette environment. +* Updated $LK,"Palette Demo",A="FI:::/Demo/Graphics/Palette.ZC"$ to use current palette environment. * Shortened $LK,"CheckPtr",A="MN:CheckPtr"$() and $LK,"CheckCodePtr",A="MN:CheckCodePtr"$(). Even though boolean expressions outside of $HL$if$HL,0$ statements are compiled inefficiently, clarity and low line count is more important. * $LK,"RawDr",A="MN:RawDumpRegs"$() is 40 columns off the right of the screen, instead of fixed at column 40. * Windows start at $LK,"4/5th the screen height",A="FF:::/Kernel/KTask.CC,text.rows"$ instead of row 13. System task window is $LK,"1/5th the screen height",A="FF:::/StartOS.CC,text.rows"$. * $LK,"R",A="MN:R"$("RLf_VGA", "$LK,"RLf_VESA",A="MN:RLf_VESA"$"); -* Removed VGA text mode support, and all definitions relating to it, including from the $LK,"kernel config",A="FI:::/Kernel/KConfig.CC"$. +* Removed VGA text mode support, and all definitions relating to it, including from the $LK,"kernel config",A="FI:::/Kernel/KConfig.ZC"$. * Added $MA-X+PU,"screen resolution selection",LM="F(\"->screen_w\");View;"$ to kernel configuration procedure. * Added $LK,"VideoRep",A="MN:VideoRep"$() to report on VBE modes and info, added test case to the $LK,"OSTestSuite",A="FF:::/Misc/OSTestSuite.CC,VideoRep"$. -* $UL$Added VBE graphics support.$UL,0$ Screen zooming is non-functional at the moment. We are setting 32-bit color graphics modes but the graphics library is still 4-bit (16 color) internally. $LK,"MiniGrLib",A="FI:/Demo/Lectures/MiniGrLib.CC"$ broken for obvious reasons. Keeping it because its intention is to teach a how a graphics library works, generically. Removed 2 smaller VGA hardware programming demos. +* $UL$Added VBE graphics support.$UL,0$ Screen zooming is non-functional at the moment. We are setting 32-bit color graphics modes but the graphics library is still 4-bit (16 color) internally. $LK,"MiniGrLib",A="FI:/Demo/Lectures/MiniGrLib.ZC"$ broken for obvious reasons. Keeping it because its intention is to teach a how a graphics library works, generically. Removed 2 smaller VGA hardware programming demos. Rundown: - Added classes $LK,"CVBEInfo",A="MN:CVBEInfo"$, $LK,"CVBEMode",A="MN:CVBEMode"$, $LK,"CVBEModeShort",A="MN:CVBEModeShort"$ - $LK,"real-mode assembly",A="FF:::/Kernel/KStart16.CC,CVBEInfo:2"$ -- $MA-X+PU,"added kernel symbols",LM="F(\"SYS_VBE\", \"+lb\");View;"$. @@ -417,7 +429,7 @@ $BK,1$* Zenith 1.0 released.$BK,0$ - $LK,"raw text drawing routine",A="FF:::/Kernel/Display.CC,text.fb_alias"$ updated. $LK,"BLACK32, WHITE32",A="MN:BLACK32"$. - Dynamic definition of $LK,"GR_WIDTH and GR_HEIGHT",A="FF:::/System/Gr/GrGlobals.CC,GR_WIDTH:2"$. - $LK,"GrUpdateScreen32",A="MN:GrUpdateScreen32"$() -- $LK,"GrCalcScreenUpdates",A="MN:GrCalcScreenUpdates"$() is used to reduce CPU usage. Added $FG,2$screen_cache$FG$ member to $LK,"CGrGlobals",A="MN:CGrGlobals"$. - - $LK,"gr_palette",A="MN:gr_palette"$ global variable. We use $LK,"CBGR24",A="MN:CBGR24"$ in $LK,"GrPalette.CC",A="FI:::/System/Gr/GrPalette.CC"$. + - $LK,"gr_palette",A="MN:gr_palette"$ global variable. We use $LK,"CBGR24",A="MN:CBGR24"$ in $LK,"GrPalette.ZC",A="FI:::/System/Gr/GrPalette.ZC"$. * Added $LK,"BinRep",A="MN:BinRep"$() from Sup1 ISO. * $LK,"R",A="MN:R"$("sys_pci_busses", "$LK,"sys_pci_buses",A="MN:sys_pci_buses"$"); @@ -425,7 +437,7 @@ $BK,1$* Zenith 1.0 released.$BK,0$ * Renamed mon_start_days1 and mon_start_days2 -> $LK,"month_start_days",A="MN:month_start_days"$ and $LK,"month_start_days_leap",A="MN:month_start_days_leap"$, respectively. * Moved random number generation algorithm into $LK,"seperate function",A="MN:RandInt"$ to reduce line count. Added $LK,"RandU8",A="MN:RandU8"$(). * Added syntax highlighting for numbers. $LK,"DocHighlight",A="FF:::/System/DolDoc/DocHighlight.CC,DOC_COLOR_NUMBER"$(), $LK,"DOC_COLOR_NUMBER",A="MN:DOC_COLOR_NUMBER"$. -* Removed unnecessary checks for the presence of the $LK,"APIC",A="MN:LAPIC_BASE"$ in $LK,"MultiProc.CC",A="FI:::/Kernel/MultiProc.CC"$, as it is present on all x86 CPUs after the P5 microarchitecture. +* Removed unnecessary checks for the presence of the $LK,"APIC",A="MN:LAPIC_BASE"$ in $LK,"MultiProc.ZC",A="FI:::/Kernel/MultiProc.ZC"$, as it is present on all x86 CPUs after the P5 microarchitecture. * Added untested $LK,"ReAlloc",A="MN:ReAlloc"$(), as it could be useful for certain programs. * Added definitions for the $LK,"PCI registers",A="MN:PCIR_VENDOR_ID"$. Expanded the $LK,"CPCIDev",A="MN:CPCIDev"$ class to contain the values of the read-only registers. Added $LK,"PCIDevFind",A="MN:PCIDevFind"$() as a simpler/abstracted alternative to $LK,"PCIClassFind",A="MN:PCIClassFind"$(). * Removed the unpolished HPET implementation from the kernel. @@ -445,7 +457,7 @@ $BK,1$* Zenith 1.0 released.$BK,0$ * AutoComplete now stays where you move it instead of snapping back to a fixed location, and that location persists after rebooting by using the Registry to save the window location. Increased number of symbol links shown to 12, so you can use all the functions keys F1-F12. It does syntax highlighting on the symbols now, so you know what type they are. Public symbols are $IV$inverted$IV,0$. Dictionary words are BLACK to differentiate between symbols. * Added more keyboard shortcuts to the AutoComplete $LK,"standby doc",A="FI:::/Doc/StandBy.DD"$. * Removed "TOS Staff" and "InsReg" related code. -* Renamed /Kernel/KInts.CC to $LK,"KInterrupts.CC",A="FI:::/Kernel/KInterrupts.CC"$. +* Renamed /Kernel/KInts.CC to $LK,"KInterrupts.ZC",A="FI:::/Kernel/KInterrupts.ZC"$. * Date section of status bar shows the year now. * Increased the length of the part of the status bar that shows the last keys pressed, so the longest combination (CTRL+ALT+SHIFT+ENTER) can be shown. It is always at the rightmost part of the screen instead of being fixed at column 55. * $LK,"ClassRep",A="MN:ClassRep"$() does not show ASCII values for U8/I8 members by default now. Added argument "u8_chars" to enable that. @@ -471,7 +483,7 @@ $BK,1$* Zenith 1.0 released.$BK,0$ * $UL$Renamed all files from .HC -> .CC to reflect language name change.$UL,0$ * Renaming: TempleOS -> ZenithOS - HolyC -> ZealC + HolyC -> CosmiC Adam -> Zenith Seth -> Daemon Chk -> Check @@ -546,11 +558,11 @@ $IV,1$----02/05/17 16:37:39----$IV,0$ * Added $LK,"::/Doc/BlkChain.DD"$. $IV,1$----02/03/17 17:27:36----$IV,0$ -* Added multicore $LK,"::/System/MathODE.CC"$. +* Added multicore $LK,"::/System/MathODE.ZC"$. * Improved support for sub and super scripts. $IV,1$----01/31/17 10:22:10----$IV,0$ -* Added $LK,"::/Demo/Graphics/LightTable.CC"$. +* Added $LK,"::/Demo/Graphics/LightTable.ZC"$. * Added $LK,"TOS Linux Setup",A="FF:::/Demo/AcctExample/TOS/TOSPolicies.DD,TOS Linux Setup"$. $IV,1$----01/27/17 08:13:37----$IV,0$ @@ -577,7 +589,7 @@ $IV,1$----01/25/17 20:44:17----$IV,0$ $IV,1$----01/24/17 21:56:06----$IV,0$ -* Improved $LK,"::/Apps/Psalmody/JukeBox.CC"$ +* Improved $LK,"::/Apps/Psalmody/JukeBox.ZC"$ * $LK,"R",A="MN:R"$("TreeBranch","Tree"); * Added $LK,"DocTreeWrite",A="MN:DocTreeWrite"$() and $LK,"DocTreeAppend",A="MN:DocTreeAppend"$(). @@ -644,7 +656,7 @@ $IV,1$----01/09/17 02:30:59----$IV,0$ $IV,1$----01/06/17 06:07:19----$IV,0$ * Fixed $LK,"DskChg",A="MN:DiskChange"$(). -* Improved $LK,"::/Misc/OSTestSuite.CC"$. +* Improved $LK,"::/Misc/OSTestSuite.ZC"$. $IV,1$----01/05/17 04:53:21----$IV,0$ * No longer support ASCII#12, CH_FORM_FEED. @@ -659,7 +671,7 @@ $IV,1$----01/04/17 18:06:14----$IV,0$ * $LK,"R",A="MN:R"$("Handler","Hndlr"); * $LK,"R",A="MN:R"$("InputPointer","Mouse"); * Improved $LK,"MemRep",A="MN:MemRep"$(). -* Changed $LK,"::/System/WallPaper.CC"$. +* Changed $LK,"::/System/WallPaper.ZC"$. $IV,1$----01/03/17 12:23:49----$IV,0$ * $LK,"R",A="MN:R"$("chars_cmp...","char_bmp..."); @@ -680,7 +692,7 @@ $IV,1$----12/31/16 07:21:20----$IV,0$ $IV,1$----12/30/16 23:42:20----$IV,0$ * $LK,"R",A="MN:R"$("Pages512","Pags"); -* Overhauled $LK,"::/Kernel/Memory/PageTables.CC"$. +* Overhauled $LK,"::/Kernel/Memory/PageTables.ZC"$. * $LK,"R",A="MN:R"$("BusyWait()","$LK,"Busy",A="MN:Busy"$()"); $IV,1$----12/29/16 10:21:44----$IV,0$ @@ -697,7 +709,7 @@ $IV,1$----12/03/16 13:19:58----$IV,0$ * $LK,"R",A="MN:R"$("SpriteX3B()","$LK,"Sprite3XB",A="MN:Sprite3XB"$()"); * $LK,"R",A="MN:R"$("SpriteY3B()","$LK,"Sprite3YB",A="MN:Sprite3YB"$()"); * $LK,"R",A="MN:R"$("SpriteZ3B()","$LK,"Sprite3ZB",A="MN:Sprite3ZB"$()"); -* Improved $LK,"::/Demo/Games/Talons.CC"$. +* Improved $LK,"::/Demo/Games/Talons.ZC"$. $IV,1$----12/03/16 10:16:26----$IV,0$ * Changed $LK,"__CMD_LINE__",A="MN:__CMD_LINE__"$. @@ -709,46 +721,46 @@ $IV,1$----11/30/16 22:44:35----$IV,0$ * Added $LK,"SpriteTransform",A="MN:SpriteTransform"$(). $IV,1$----11/28/16 07:11:41----$IV,0$ -* Improved $LK,"::/Apps/Titanium/Titanium.CC"$. +* Improved $LK,"::/Apps/Titanium/Titanium.ZC"$. $IV,1$----11/26/16 22:43:51----$IV,0$ -* Added solar storms to $LK,"::/Apps/X-Caliber/X-Caliber.CC"$. +* Added solar storms to $LK,"::/Apps/X-Caliber/X-Caliber.ZC"$. * $LK,"R",A="MN:R"$("TimeOut","Titanium"); $IV,1$----11/20/16 19:46:43----$IV,0$ * $BK,1$TempleOS version 4.13 Released$BK,0$ -* Improved $LK,"::/Apps/Titanium/Titanium.CC"$. -* Improved $LK,"::/Apps/X-Caliber/X-Caliber.CC"$. +* Improved $LK,"::/Apps/Titanium/Titanium.ZC"$. +* Improved $LK,"::/Apps/X-Caliber/X-Caliber.ZC"$. $IV,1$----11/19/16 08:19:51----$IV,0$ * Improved Budget application. $IV,1$----11/17/16 18:49:51----$IV,0$ * $LK,"R",A="MN:R"$("EagleDive","Talons"); -* Improved $LK,"::/Demo/Games/RocketScience.CC"$. -* Improved $LK,"::/Demo/Games/Rocket.CC"$. +* Improved $LK,"::/Demo/Games/RocketScience.ZC"$. +* Improved $LK,"::/Demo/Games/Rocket.ZC"$. $IV,1$----10/28/16 05:54:27----$IV,0$ -* Added $LK,"::/Demo/RadixSort.CC"$. +* Added $LK,"::/Demo/RadixSort.ZC"$. $IV,1$----10/26/16 00:21:06----$IV,0$ * Added $LK,"CProgress",A="MN:CProgress"$.t0. * Improved $LK,"::/Doc/Boot.DD"$. $IV,1$----10/25/16 18:02:44----$IV,0$ -* Improved $LK,"::/System/Gr/SpriteEd.CC"$. +* Improved $LK,"::/System/Gr/SpriteEd.ZC"$. * Improved $LK,"::/Demo/AcctExample/TOS/TOSHolySpirit.HC"$. $IV,1$----10/12/16 10:55:26----$IV,0$ * Added $LK,"CCF_NO_CHAR_CONST",A="MN:CCF_NO_CHAR_CONST"$. -* Improved $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +* Improved $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. $IV,1$----10/03/16 01:09:35----$IV,0$ * Changed $LK,"GodWord",A="MN:GodWord"$(). $IV,1$----09/30/16 18:29:59----$IV,0$ * Improved $LK,"Rand",A="MN:Rand"$()'s. -* Improved $LK,"::/System/Utils/ToTXT.CC"$. +* Improved $LK,"::/System/Utils/ToTXT.ZC"$. $IV,1$----09/29/16 10:13:14----$IV,0$ * $BK,1$TempleOS version 4.12 Released$BK,0$ @@ -758,10 +770,10 @@ $IV,1$----09/29/16 10:13:14----$IV,0$ $IV,1$----09/27/16 12:40:21----$IV,0$ * Added $LK,"SndRst",A="MN:SoundReset"$(). -* Got rid of crappy reverb in $LK,"::/Apps/Psalmody/PsalmodyMain.CC"$. +* Got rid of crappy reverb in $LK,"::/Apps/Psalmody/PsalmodyMain.ZC"$. $IV,1$----09/27/16 11:09:25----$IV,0$ -* Improved $LK,"::/Misc/OSTestSuite.CC"$. +* Improved $LK,"::/Misc/OSTestSuite.ZC"$. * Fixed bug in $LK,"EdCharIns",A="MN:EdCharIns"$() printing $$ cmds. * Added $LK,"FUF_JUST_DD",A="MN:FUF_JUST_DD"$ and $LK,"FILEMASK_DD",A="MN:FILEMASK_DD"$. @@ -772,14 +784,14 @@ $IV,1$----09/27/16 01:05:52----$IV,0$ * $LK,"R",A="MN:R"$("Temp","Tmp"); $IV,1$----09/26/16 00:44:42----$IV,0$ -* Added CloseAssault and OverRun to $LK,"::/Apps/ToTheFront/ToTheFront.CC"$. +* Added CloseAssault and OverRun to $LK,"::/Apps/ToTheFront/ToTheFront.ZC"$. $IV,1$----09/22/16 07:53:20----$IV,0$ -* Improved $LK,"::/Demo/Graphics/Box.CC"$. -* Improved $LK,"::/Demo/Graphics/SpritePlot3D.CC"$. +* Improved $LK,"::/Demo/Graphics/Box.ZC"$. +* Improved $LK,"::/Demo/Graphics/SpritePlot3D.ZC"$. $IV,1$----09/21/16 17:09:40----$IV,0$ -* Fixed bug in $LK,"::/Demo/Games/BomberGolf.CC"$. +* Fixed bug in $LK,"::/Demo/Games/BomberGolf.ZC"$. $IV,1$----09/20/16 15:57:30----$IV,0$ * $LK,"R",A="MN:R"$("Screen","Scrn"); @@ -811,11 +823,11 @@ $IV,1$----09/06/16 13:01:42----$IV,0$ * Got rid of $FG,4$MSG_FOCUS$FG$, $FG,4$MSG_MOVE$FG$, and $FG,4$MSG_SIZE$FG$. There are no longer messages for moving and sizing windows. $IV,1$----09/06/16 02:40:43----$IV,0$ -* Improved $LK,"::/Demo/MagicPairs.CC"$. +* Improved $LK,"::/Demo/MagicPairs.ZC"$. $IV,1$----08/27/16 09:45:39----$IV,0$ * Improved $LK,"CPURep",A="MN:CPURep"$(). -* Improved $LK,"::/Misc/OSTestSuite.CC"$. +* Improved $LK,"::/Misc/OSTestSuite.ZC"$. * Added $LK,"BirthWait",A="MN:BirthWait"$() and $LK,"DeathWait",A="MN:DeathWait"$(). $IV,1$----08/22/16 04:14:47----$IV,0$ @@ -825,11 +837,11 @@ $IV,1$----07/17/16 13:03:12----$IV,0$ * Improved $LK,"DocOpt",A="MN:DocOpt"$(). $IV,1$----07/17/16 03:23:53----$IV,0$ -* Improved $LK,"::/Demo/Games/RawHide.CC"$. +* Improved $LK,"::/Demo/Games/RawHide.ZC"$. $IV,1$----07/15/16 10:11:10----$IV,0$ * $BK,1$TempleOS version 4.10 Released$BK,0$ -* Improved $LK,"::/Demo/Games/Talons.CC"$. +* Improved $LK,"::/Demo/Games/Talons.ZC"$. $IV,1$----07/15/16 05:17:24----$IV,0$ * Created $LK,"CDevGlbls",A="MN:CDevGlobals"$.uncached_alias. @@ -839,7 +851,7 @@ $IV,1$----07/13/16 17:21:19----$IV,0$ * Added multicore report to $LK,"CPURep",A="MN:CPURep"$(). $IV,1$----07/09/16 08:46:36----$IV,0$ -* Changed scoring in $LK,"::/Demo/Games/Talons.CC"$. +* Changed scoring in $LK,"::/Demo/Games/Talons.ZC"$. * Replaced many $FG,2$"%Q"$FG$ with $FG,2$"%$$Q"$FG$. * Fixed $FG,2$'\x24'$FG$. * Added $FG,2$'\d'$FG$ for $FG,2$'$$'$FG$. @@ -854,11 +866,11 @@ $IV,1$----07/07/16 07:21:03----$IV,0$ $IV,1$----07/06/16 23:45:30----$IV,0$ * Fixed multicore bug in $LK,"Sprite3",A="MN:Sprite3"$(). -* Improved $LK,"::/Demo/Games/Talons.CC"$. +* Improved $LK,"::/Demo/Games/Talons.ZC"$. $IV,1$----07/05/16 06:03:47----$IV,0$ * $BK,1$TempleOS version 4.09 Released$BK,0$ -* Improved $LK,"::/Demo/Games/Talons.CC"$. +* Improved $LK,"::/Demo/Games/Talons.ZC"$. * Improved $LK,"GrFillTri0",A="MN:GrFillTri0"$(). $IV,1$----07/03/16 04:30:05----$IV,0$ @@ -871,14 +883,14 @@ $IV,1$----07/01/16 05:29:08----$IV,0$ $IV,1$----06/28/16 13:15:08----$IV,0$ * Changed $LK,"TaskRep",A="MN:TaskRep"$() and $LK,"MemRep",A="MN:MemRep"$(). -* Changed $LK,"::/System/WallPaper.CC"$. +* Changed $LK,"::/System/WallPaper.ZC"$. $IV,1$----06/26/16 14:01:16----$IV,0$ * Added $LK,"LastFun",A="MN:LastFun"$(), $LK,"RunFile",A="MN:RunFile"$(), $LK,"RunFile2",A="MN:RunFile2"$() and $LK,"PopUpRunFile",A="MN:PopUpRunFile"$(). * Made boot code modular. $IV,1$----06/24/16 14:15:13----$IV,0$ -* Added A.I. to $LK,"::/Apps/KeepAway/KeepAway.CC"$ and changed scoring. +* Added A.I. to $LK,"::/Apps/KeepAway/KeepAway.ZC"$ and changed scoring. $IV,1$----06/24/16 02:55:42----$IV,0$ * $BK,1$TempleOS version 4.08 Released$BK,0$ @@ -905,10 +917,10 @@ $IV,1$----06/16/16 20:59:41----$IV,0$ * $FG,2$$FG$ is next task. $IV,1$----06/16/16 19:49:39----$IV,0$ -* Added $LK,"::/Doc/Comm.CC"$. +* Added $LK,"::/Doc/Comm.ZC"$. * Added $LK,"::/Doc/StdTempleOSPC.DD"$. * Added $LK,"::/Kernel/FontCyrillic.HC"$. $FG,2$$FG$ $IV,1$----06/02/16 03:20:56----$IV,0$ * $BK,1$TempleOS version 4.07 Released$BK,0$ -* Added claws to $LK,"::/Demo/Games/Talons.CC"$. +* Added claws to $LK,"::/Demo/Games/Talons.ZC"$. diff --git a/src/Doc/CharOverview.DD b/src/Doc/CharOverview.DD index c0bcf449..16904333 100755 --- a/src/Doc/CharOverview.DD +++ b/src/Doc/CharOverview.DD @@ -19,7 +19,7 @@ The upper 4-bytes are copied from lower 4-bytes. $FG,2$Byte 4$FG$ is the code. Left, Right and NumPad keys distinct. $FG,2$Byte 5-7$FG$ are $LK,"flags",A="MN:SCf_KEY_UP"$ -Run the program $LK,"::/Demo/MessageLoop.CC"$ to examine scan code. Press $FG,2$$FG$ and "Insert ASCII/ScanCode".$FG$ +Run the program $LK,"::/Demo/MessageLoop.ZC"$ to examine scan code. Press $FG,2$$FG$ and "Insert ASCII/ScanCode".$FG$ See $LK,"Key Allocations",A="FI:::/Doc/KeyAlloc.DD"$ and $LK,"CKbdStateGlobals",A="MN:CKbdStateGlobals"$. diff --git a/src/Doc/CmdLineOverview.DD b/src/Doc/CmdLineOverview.DD index 12147570..538640aa 100755 --- a/src/Doc/CmdLineOverview.DD +++ b/src/Doc/CmdLineOverview.DD @@ -14,7 +14,7 @@ If you don't have args, you don't need parenthesis. Directories are referenced with $FG,2$/$FG$ not $FG,2$\$FG$. There is a current directory, but not a path. To run a program, you typically $FG,2$#include $FG$it. There are several shortcuts for $FG,2$#include$FG$ing files. Right-click or hit $FG,2$$FG$ on a directory listing or press $FG,2$$FG$ while editing. ->$FG,2$Ed("NewFile.CC");$FG$ Invokes the editor. See $LK,"Doc Link Type",A="MN:LK_FILE"$. +>$FG,2$Ed("NewFile.ZC");$FG$ Invokes the editor. See $LK,"Doc Link Type",A="MN:LK_FILE"$. Drives are specified with a letter. The boot drive is specified with a '$FG,2$:$FG$'. The home dir drive is specified with a $FG,2$'~'$FG$. @@ -33,7 +33,7 @@ If a file is not found, all parent directories are searched. You can place macros in your $LK,"PersonalMenu",A="FI:~/PersonalMenu.DD"$ for $LK,"Cd",A="MN:Cd"$() commands. $FG,2$$FG$ to access your menu. ->$FG,2$Find("needle","/Demo/*.CC;*.DD;");$FG$ See $LK,"File Utils",A="FI:::/Doc/FileUtils.DD"$. +>$FG,2$Find("needle","/Demo/*.ZC;*.DD;");$FG$ See $LK,"File Utils",A="FI:::/Doc/FileUtils.DD"$. $LK,"Cmd Line Routines",A="HI:Cmd Line (Typically)"$ diff --git a/src/Doc/Comm.CC b/src/Doc/Comm.ZC similarity index 100% rename from src/Doc/Comm.CC rename to src/Doc/Comm.ZC diff --git a/src/Doc/CompilerOverview.DD b/src/Doc/CompilerOverview.DD index fa1cdbae..6501ca1f 100755 --- a/src/Doc/CompilerOverview.DD +++ b/src/Doc/CompilerOverview.DD @@ -3,8 +3,8 @@ $WW,1$$FG,5$$TX+CX,"Compiler Index"$$FG$ The compiler lexes and parses code into $LK,"Intermediate Codes",A="FF:::/Compiler/CompilerA.HH,IC_END"$ which are then made into JIT or AOT machine code. The compiler preprocesses during lexing, and optimizes after Intermediate Code generation. For parser reference, see $LK,"ParseExpression",A="MN:ParseExpression"$(), $LK,"ParseStatement",A="MN:ParseStatement"$(). -For Intermediate Code reference, see $LK,"BackLib",A="FI:::/Compiler/BackLib.CC"$, $LK,"Intermediate Code Attributes",A="MN:intermediate_code_table"$, $LK,"Combining Consts",A="FF:::/Compiler/OptPass012.CC,case IC_MUL"$, $LK,"Choosing Reg Vars",A="FF:::/Compiler/OptPass3.CC,cmp.num_reg_vars"$. -For machine code backend reference, see $LK,"IC Struct",A="MN:CIntermediateCode"$, $LK,"COCCompile",A="MN:COCCompile"$ and $LK,"OptPass789A",A="FF:::/Compiler/OptPass789A.CC,IC_MUL"$(), $LK,"BackEnd",A="FF:::/Compiler/BackA.CC,ICMul"$. +For Intermediate Code reference, see $LK,"BackLib",A="FI:::/Compiler/BackLib.ZC"$, $LK,"Intermediate Code Attributes",A="MN:intermediate_code_table"$, $LK,"Combining Consts",A="FF:::/Compiler/OptPass012.ZC,case IC_MUL"$, $LK,"Choosing Reg Vars",A="FF:::/Compiler/OptPass3.ZC,cmp.num_reg_vars"$. +For machine code backend reference, see $LK,"IC Struct",A="MN:CIntermediateCode"$, $LK,"COCCompile",A="MN:COCCompile"$ and $LK,"OptPass789A",A="FF:::/Compiler/OptPass789A.ZC,IC_MUL"$(), $LK,"BackEnd",A="FF:::/Compiler/BackA.ZC,ICMul"$. $LK,"::/Doc/Asm.DD"$ diff --git a/src/Doc/Credits.DD b/src/Doc/Credits.DD index 967d10ea..6351f9ce 100755 --- a/src/Doc/Credits.DD +++ b/src/Doc/Credits.DD @@ -4,9 +4,9 @@ $FG,2$Terry A. Davis$FG$ wrote all of TempleOS over a span of $FG,2$$TX,"15.0",D *) $LK,"ATA Reg and Cmd Definitions",A="MN:ATA_NOP"$ are originally from Linux. Later, Terry got the spec. -*) The heap algorithm, $LK,"::/Kernel/Memory/MAllocFree.CC"$, is adapted from one Terry saw at Ticketmaster when he worked on their VAX operating system. +*) The heap algorithm, $LK,"::/Kernel/Memory/MAllocFree.ZC"$, is adapted from one Terry saw at Ticketmaster when he worked on their VAX operating system. -*) The adaptive-step-size-Runge-Kutta algorithm, $LK,"::/System/MathODE.CC"$, is adapted from the book, $UL,1$Numerical Recipes in C$UL,0$. +*) The adaptive-step-size-Runge-Kutta algorithm, $LK,"::/System/MathODE.ZC"$, is adapted from the book, $UL,1$Numerical Recipes in C$UL,0$. *) The mountain in some games is from $FG,4$$TX,"http://www.public-domain-photos.com",HTML="http://www.public-domain-photos.com"$$FG$. The wolf in BlackDiamond is also from there. Terry took watermarked photos and converted to 16 color. @@ -16,7 +16,7 @@ $FG,2$Terry A. Davis$FG$ wrote all of TempleOS over a span of $FG,2$$TX,"15.0",D *) Terry included $LK,"PCIDevice List File",A="FI:::/Misc/PCIDevices.DD",HTML="http://www.pcidatabase.com/reports.php?type=tab-delimeted"$. -*) Thanks to whoever wrote this $FG,4$$TX,"CppHtml.CC",HTML="http://web.archive.org/web/20100325153025/http://home.scarlet.be/zoetrope/cpphtml.htm"$$FG$. Terry was a novice on web stuff and you helped him with html. See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +*) Thanks to whoever wrote this $FG,4$$TX,"CppHtml.ZC",HTML="http://web.archive.org/web/20100325153025/http://home.scarlet.be/zoetrope/cpphtml.htm"$$FG$. Terry was a novice on web stuff and you helped him with html. See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. *) Terry looked at bootable CD boot sectors, but didn't learn anything, finding it easier to make his own. diff --git a/src/Doc/Ctrls.DD b/src/Doc/Ctrls.DD index 45dbb690..99a6e257 100755 --- a/src/Doc/Ctrls.DD +++ b/src/Doc/Ctrls.DD @@ -1 +1 @@ -$WW,1$To create a ZealOS graphic ctrl, you define callback functions and insert a $LK,"CCtrl",A="MN:CCtrl"$ structure in the $LK,"CTask",A="MN:CTask"$ queue. See $LK,"::/Demo/Graphics/Slider.CC"$, $LK,"::/Demo/Graphics/ScrollBars.CC"$ and $LK,"TermBttnNew",A="FF:::/System/WallPaper.CC,TermBttnNew"$. There is a template-code ctrl generator, if you press $FG,2$$FG$. +$WW,1$To create a ZealOS graphic ctrl, you define callback functions and insert a $LK,"CCtrl",A="MN:CCtrl"$ structure in the $LK,"CTask",A="MN:CTask"$ queue. See $LK,"::/Demo/Graphics/Slider.ZC"$, $LK,"::/Demo/Graphics/ScrollBars.ZC"$ and $LK,"TermBttnNew",A="FF:::/System/WallPaper.ZC,TermBttnNew"$. There is a template-code ctrl generator, if you press $FG,2$$FG$. diff --git a/src/Doc/Customize.DD b/src/Doc/Customize.DD index f452d1f7..4bd3a569 100755 --- a/src/Doc/Customize.DD +++ b/src/Doc/Customize.DD @@ -1,7 +1,7 @@ -$WW,1$* You can adjust the mouse movement rate by setting global variables in your start-up file. See $LK,"mouse scale",A="FF:~/HomeLocalize.CC,mouse_hard.scale"$. +$WW,1$* You can adjust the mouse movement rate by setting global variables in your start-up file. See $LK,"mouse scale",A="FF:~/HomeLocalize.ZC,mouse_hard.scale"$. -* You can set your local time zone by setting the $FG,4$local_time_offset$FG$ global variable in a start-up file. Its units are $LK,"CDATE_FREQ",A="MN:CDATE_FREQ"$. See $LK,"local time",A="FF:~/HomeLocalize.CC,local_time"$. +* You can set your local time zone by setting the $FG,4$local_time_offset$FG$ global variable in a start-up file. Its units are $LK,"CDATE_FREQ",A="MN:CDATE_FREQ"$. See $LK,"local time",A="FF:~/HomeLocalize.ZC,local_time"$. -* You can change the palette using the $LK+PU,"PaletteSet",A="FF:::/System/Gr/GrPalette.CC,U0 PaletteSet"$ functions. Pressing $FG,2$$FG$ toggles standard and VGA ROM font. +* You can change the palette using the $LK+PU,"PaletteSet",A="FF:::/System/Gr/GrPalette.ZC,U0 PaletteSet"$ functions. Pressing $FG,2$$FG$ toggles standard and VGA ROM font. -* Get rid of this message $LK,"here",A="FF:~/Once.CC,Customize.DD"$. +* Get rid of this message $LK,"here",A="FF:~/Once.ZC,Customize.DD"$. diff --git a/src/Doc/CutCorners.DD b/src/Doc/CutCorners.DD index 39b0f873..14c4e8f6 100755 --- a/src/Doc/CutCorners.DD +++ b/src/Doc/CutCorners.DD @@ -6,7 +6,7 @@ There are a few places where corners are cut in the interest of not junking-up c * ZealOS does not figure-out $FG,2$FAT32$FG$ short name alias numbers. $LK,"FAT32DirNew",A="MN:FAT32DirNew"$(). It can cause hard drive corruption, so it might have to do it eventually. It would really take a lot of junky code for this hatefully, detestable, legacy issue. "Please don't make us ruin the beautiful shiny-new ZealOS with that!" $FG,2$FAT32$FG$ is also unappealing because it is in patent limbo. $FG,2$FAT32$FG$ might get removed from ZealOS. There is the $LK,"RedSea",A="FI:::/Doc/RedSea.DD"$ 64-bit file system that works perfectly well. $FG,2$FAT32$FG$ is useful, however, because it assists in transferring between dual booted operating systems. -* The $LK,"asm opcodes",A="FI:::/Compiler/OpCodes.DD"$ names were changed to remove the ambiguity between insts with different numbers of arguments, making the $LK,"assembler",A="FI:::/Compiler/Asm.CC"$ simpler and minimal 16-bit asm support was done, since 64-bit is what you should be using, unless you're doing a $LK,"boot loader",A="FI:::/System/Boot/BootDVD.CC"$. +* The $LK,"asm opcodes",A="FI:::/Compiler/OpCodes.DD"$ names were changed to remove the ambiguity between insts with different numbers of arguments, making the $LK,"assembler",A="FI:::/Compiler/Asm.ZC"$ simpler and minimal 16-bit asm support was done, since 64-bit is what you should be using, unless you're doing a $LK,"boot loader",A="FI:::/System/Boot/BootDVD.ZC"$. * There are no user-controlled file-sharing locks. However, the drive and file system have locks and concurrent operations should be fine. diff --git a/src/Doc/Define.DD b/src/Doc/Define.DD index 36c7d9a2..fdeb4607 100755 --- a/src/Doc/Define.DD +++ b/src/Doc/Define.DD @@ -1,9 +1,9 @@ -$WW,1$ZealOS has a string indirection feature implemented with the same hash symbol table entry as $FG,2$#define$FG$ macros, $LK,"HTT_DEFINE_STR",A="MN:HTT_DEFINE_STR"$. Support for string lists is also provided, but it's not very efficient, though, you can make a hash table with a list using $LK,"HashDefineListAdd",A="MN:HashDefineListAdd"$(). See $LK,"::/System/DolDoc/DocInit.CC",A="FF:::/System/DolDoc/DocInit.CC,HashDefineListAdd"$. +$WW,1$ZealOS has a string indirection feature implemented with the same hash symbol table entry as $FG,2$#define$FG$ macros, $LK,"HTT_DEFINE_STR",A="MN:HTT_DEFINE_STR"$. Support for string lists is also provided, but it's not very efficient, though, you can make a hash table with a list using $LK,"HashDefineListAdd",A="MN:HashDefineListAdd"$(). See $LK,"::/System/DolDoc/DocInit.ZC",A="FF:::/System/DolDoc/DocInit.ZC,HashDefineListAdd"$. If you have an $FG,2$@$FG$ as the first char of a define list entry, it is an alias for the prev entry num. Each task can load its own Define strings. Remember, when a $LK,"Hash",A="HI:Hash"$ table is searched for a string, if it is not found, the parent task's table is searched. -The $LK,"DolDoc",A="FI:::/Doc/DolDocOverview.DD"$ framework supports text that changes based on entries in the task's symbol table. Set a text entry with a $FG,2$D=$FG$ arg, as in $FG,2$$$TX,"",D="DD_MYSTRING"$$$FG$. See $LK,"::/Demo/DolDoc/DefineStr.CC"$, $LK,"::/System/Define.CC"$ and $LK,"::/Doc/MemoryOverview.DD"$. +The $LK,"DolDoc",A="FI:::/Doc/DolDocOverview.DD"$ framework supports text that changes based on entries in the task's symbol table. Set a text entry with a $FG,2$D=$FG$ arg, as in $FG,2$$$TX,"",D="DD_MYSTRING"$$$FG$. See $LK,"::/Demo/DolDoc/DefineStr.ZC"$, $LK,"::/System/Define.ZC"$ and $LK,"::/Doc/MemoryOverview.DD"$. -See $LK,"::/Demo/Define.CC"$. +See $LK,"::/Demo/Define.ZC"$. diff --git a/src/Doc/DemoIndex.DD b/src/Doc/DemoIndex.DD index 07516b79..7936dba8 100755 --- a/src/Doc/DemoIndex.DD +++ b/src/Doc/DemoIndex.DD @@ -7,187 +7,187 @@ $FG,2$$FG$ to edit a file and $FG,2$$FG$ to run it. $LK,"::/Doc/HelloWorld.DD"$ $WW,0$$TR,"Games: Beginner"$ -$ID,2$$LK,"::/Demo/Graphics/NetOfDots.CC"$ -$LK,"::/Demo/Graphics/MouseDemo.CC"$ -$LK,"::/Demo/Graphics/Lines.CC"$ -$LK,"::/Demo/Graphics/SunMoon.CC"$ -$LK,"::/Demo/Graphics/LowPassFilter.CC"$ -$LK,"::/Demo/Graphics/MathAudioDemo.CC"$ -$LK,"::/Demo/Games/TicTacToe.CC"$ -$LK,"::/Demo/Graphics/SpritePlot.CC"$ -$LK,"::/Demo/Games/ElephantWalk.CC"$ -$LK,"::/Demo/Graphics/SpritePut.CC"$ -$LK,"::/Demo/Graphics/SpritePutExt.CC"$ -$LK,"::/Demo/Sound/ASCIIOrgan.CC"$ -$LK,"::/Demo/MessageLoop.CC"$ -$LK,"::/Demo/Graphics/Doodle.CC"$ -$LK,"::/Demo/Graphics/Speedline.CC"$ -$LK,"::/Demo/Graphics/Bounce.CC"$ -$LK,"::/Demo/RandDemo.CC"$ -$LK,"::/Demo/KeyBitMap.CC"$ -$LK,"::/Demo/Graphics/WinZBuf.CC"$ -$LK,"::/Demo/Graphics/Elephant.CC"$ -$LK,"::/Demo/Graphics/WallPaperFish.CC"$ //Press SHIFT-F5 to System Include -$LK,"::/Demo/Games/Digits.CC"$ -$LK,"::/Demo/Progress.CC"$ //has some ASM, just ignore -$LK,"::/Demo/Graphics/Symmetry.CC"$ -$LK,"::/Demo/Graphics/Blot.CC"$ -$LK,"::/Demo/Graphics/ScreenCapture.CC"$ -$LK,"::/Demo/Graphics/EdSprite.CC"$ -$LK,"::/Demo/PullDownMenu.CC"$ -$LK,"::/Demo/Graphics/Palette.CC"$ -$LK,"::/Demo/Games/CircleTrace.CC"$ -$LK,"::/Demo/Games/Halogen.CC"$ -$LK,"::/Demo/Games/TheDead.CC"$ -$LK,"::/Demo/Games/RainDrops.CC"$ -$LK,"::/Demo/Sound/MorseCode.CC"$ +$ID,2$$LK,"::/Demo/Graphics/NetOfDots.ZC"$ +$LK,"::/Demo/Graphics/MouseDemo.ZC"$ +$LK,"::/Demo/Graphics/Lines.ZC"$ +$LK,"::/Demo/Graphics/SunMoon.ZC"$ +$LK,"::/Demo/Graphics/LowPassFilter.ZC"$ +$LK,"::/Demo/Graphics/MathAudioDemo.ZC"$ +$LK,"::/Demo/Games/TicTacToe.ZC"$ +$LK,"::/Demo/Graphics/SpritePlot.ZC"$ +$LK,"::/Demo/Games/ElephantWalk.ZC"$ +$LK,"::/Demo/Graphics/SpritePut.ZC"$ +$LK,"::/Demo/Graphics/SpritePutExt.ZC"$ +$LK,"::/Demo/Sound/ASCIIOrgan.ZC"$ +$LK,"::/Demo/MessageLoop.ZC"$ +$LK,"::/Demo/Graphics/Doodle.ZC"$ +$LK,"::/Demo/Graphics/Speedline.ZC"$ +$LK,"::/Demo/Graphics/Bounce.ZC"$ +$LK,"::/Demo/RandDemo.ZC"$ +$LK,"::/Demo/KeyBitMap.ZC"$ +$LK,"::/Demo/Graphics/WinZBuf.ZC"$ +$LK,"::/Demo/Graphics/Elephant.ZC"$ +$LK,"::/Demo/Graphics/WallPaperFish.ZC"$ //Press SHIFT-F5 to System Include +$LK,"::/Demo/Games/Digits.ZC"$ +$LK,"::/Demo/Progress.ZC"$ //has some ASM, just ignore +$LK,"::/Demo/Graphics/Symmetry.ZC"$ +$LK,"::/Demo/Graphics/Blot.ZC"$ +$LK,"::/Demo/Graphics/ScreenCapture.ZC"$ +$LK,"::/Demo/Graphics/EdSprite.ZC"$ +$LK,"::/Demo/PullDownMenu.ZC"$ +$LK,"::/Demo/Graphics/Palette.ZC"$ +$LK,"::/Demo/Games/CircleTrace.ZC"$ +$LK,"::/Demo/Games/Halogen.ZC"$ +$LK,"::/Demo/Games/TheDead.ZC"$ +$LK,"::/Demo/Games/RainDrops.ZC"$ +$LK,"::/Demo/Sound/MorseCode.ZC"$ $MA-X+PU,"::/Demo/Games/Stadium",LM="Cd(\"::/Demo/Games/Stadium\");Dir;View;\n"$ -$LK,"::/Demo/Graphics/Lattice.CC"$ -$LK,"::/Demo/Graphics/Collision.CC"$ -$LK,"::/Demo/Games/BlackDiamond.CC"$ +$LK,"::/Demo/Graphics/Lattice.ZC"$ +$LK,"::/Demo/Graphics/Collision.ZC"$ +$LK,"::/Demo/Games/BlackDiamond.ZC"$ $ID,-2$$TR,"Games: Intermediate"$ -$ID,2$$LK,"::/Demo/Graphics/Box.CC"$ -$LK,"::/Demo/Graphics/Pick.CC"$ -$LK,"::/Demo/Graphics/3DPoly.CC"$ -$LK,"::/Demo/Graphics/BSpline.CC"$ -$LK,"::/Demo/Graphics/Extents.CC"$ -$LK,"::/Demo/Graphics/SpritePlot3D.CC"$ -$LK,"::/Demo/Graphics/RotateTank.CC"$ -$LK,"::/Demo/Games/Wenceslas.CC"$ -$LK,"::/Demo/ScreenCodes.CC"$ -$LK,"::/Demo/Graphics/PanText.CC"$ -$LK,"::/Demo/Graphics/CharAnimation.CC"$ -$LK,"::/Demo/Games/Maze.CC"$ -$LK,"::/Demo/Games/CharDemo.CC"$ -$LK,"::/Demo/Graphics/FontEd.CC"$ -$LK,"::/Demo/ExtChars.CC"$ -$LK,"::/Demo/TimeIns.CC"$ -$LK,"::/Demo/Sound/WaterFowl.CC"$ +$ID,2$$LK,"::/Demo/Graphics/Box.ZC"$ +$LK,"::/Demo/Graphics/Pick.ZC"$ +$LK,"::/Demo/Graphics/3DPoly.ZC"$ +$LK,"::/Demo/Graphics/BSpline.ZC"$ +$LK,"::/Demo/Graphics/Extents.ZC"$ +$LK,"::/Demo/Graphics/SpritePlot3D.ZC"$ +$LK,"::/Demo/Graphics/RotateTank.ZC"$ +$LK,"::/Demo/Games/Wenceslas.ZC"$ +$LK,"::/Demo/ScreenCodes.ZC"$ +$LK,"::/Demo/Graphics/PanText.ZC"$ +$LK,"::/Demo/Graphics/CharAnimation.ZC"$ +$LK,"::/Demo/Games/Maze.ZC"$ +$LK,"::/Demo/Games/CharDemo.ZC"$ +$LK,"::/Demo/Graphics/FontEd.ZC"$ +$LK,"::/Demo/ExtChars.ZC"$ +$LK,"::/Demo/TimeIns.ZC"$ +$LK,"::/Demo/Sound/WaterFowl.ZC"$ $MA-X+PU,"::/Apps/Psalmody/Examples",LM="Cd(\"::/Apps/Psalmody/Examples\");Dir;View;\n"$ $LK,"CPURep",A="MN:CPURep"$ -$LK,"::/Demo/MultiCore/MPPrint.CC"$ -$LK,"::/Demo/Graphics/PredatorPrey.CC"$ -$LK,"::/Demo/Graphics/Cartesian.CC"$ -$LK,"::/Demo/Graphics/Hanoi.CC"$ -$LK,"::/Demo/Graphics/Life.CC"$ -$LK,"::/Demo/Games/Zing.CC"$ -$LK,"::/Demo/Graphics/Grid.CC"$ -$LK,"::/Demo/Games/TreeCheckers.CC"$ -$LK,"::/Demo/MultiCore/Palindrome.CC"$ -$LK,"::/Demo/MultiCore/MPAdd.CC"$ -$LK,"::/Demo/MultiCore/Lock.CC"$ -$LK,"::/Demo/Graphics/Slider.CC"$ -$LK,"::/Demo/Graphics/WallPaperCtrl.CC"$ //Press SHIFT-F5 to System Include -$LK,"::/Demo/Graphics/ScrollBars.CC"$ -$LK,"::/Demo/RegistryDemo.CC"$ -$LK,"::/Demo/Games/FlapBat.CC"$ -$LK,"::/Demo/Games/BattleLines.CC"$ -$LK,"::/Demo/Games/BigGuns.CC"$ -$LK,"::/Demo/Games/FlatTops.CC"$ -$LK,"::/Demo/Games/RawHide.CC"$ -$LK,"::/Demo/Games/DunGen.CC"$ +$LK,"::/Demo/MultiCore/MPPrint.ZC"$ +$LK,"::/Demo/Graphics/PredatorPrey.ZC"$ +$LK,"::/Demo/Graphics/Cartesian.ZC"$ +$LK,"::/Demo/Graphics/Hanoi.ZC"$ +$LK,"::/Demo/Graphics/Life.ZC"$ +$LK,"::/Demo/Games/Zing.ZC"$ +$LK,"::/Demo/Graphics/Grid.ZC"$ +$LK,"::/Demo/Games/TreeCheckers.ZC"$ +$LK,"::/Demo/MultiCore/Palindrome.ZC"$ +$LK,"::/Demo/MultiCore/MPAdd.ZC"$ +$LK,"::/Demo/MultiCore/Lock.ZC"$ +$LK,"::/Demo/Graphics/Slider.ZC"$ +$LK,"::/Demo/Graphics/WallPaperCtrl.ZC"$ //Press SHIFT-F5 to System Include +$LK,"::/Demo/Graphics/ScrollBars.ZC"$ +$LK,"::/Demo/RegistryDemo.ZC"$ +$LK,"::/Demo/Games/FlapBat.ZC"$ +$LK,"::/Demo/Games/BattleLines.ZC"$ +$LK,"::/Demo/Games/BigGuns.ZC"$ +$LK,"::/Demo/Games/FlatTops.ZC"$ +$LK,"::/Demo/Games/RawHide.ZC"$ +$LK,"::/Demo/Games/DunGen.ZC"$ $MA-X+PU,"::/Apps/Titanium",LM="Cd(\"::/Apps/Titanium\");Dir;View;\n"$ -$LK,"::/Demo/Games/Collision.CC"$ +$LK,"::/Demo/Games/Collision.ZC"$ $ID,-2$$TR,"Games: Advanced"$ -$ID,2$$LK,"::/Demo/MultiCore/LoadTest.CC"$ -$LK,"::/Demo/MultiCore/Primes.CC"$ -$LK,"::/Demo/MultiCore/MPRadix.CC"$ -$LK,"::/Demo/MultiCore/Interrupts.CC"$ -$LK,"::/Demo/Games/Varoom.CC"$ -$LK,"::/Demo/Graphics/Shading.CC"$ -$LK,"::/Demo/Graphics/Transform.CC"$ -$LK,"::/Demo/Games/BomberGolf.CC"$ -$LK,"::/Demo/Graphics/Shadow.CC"$ -$LK,"::/Demo/Graphics/Pick3D.CC"$ +$ID,2$$LK,"::/Demo/MultiCore/LoadTest.ZC"$ +$LK,"::/Demo/MultiCore/Primes.ZC"$ +$LK,"::/Demo/MultiCore/MPRadix.ZC"$ +$LK,"::/Demo/MultiCore/Interrupts.ZC"$ +$LK,"::/Demo/Games/Varoom.ZC"$ +$LK,"::/Demo/Graphics/Shading.ZC"$ +$LK,"::/Demo/Graphics/Transform.ZC"$ +$LK,"::/Demo/Games/BomberGolf.ZC"$ +$LK,"::/Demo/Graphics/Shadow.ZC"$ +$LK,"::/Demo/Graphics/Pick3D.ZC"$ $MA-X+PU,"::/Apps/ToTheFront",LM="Cd(\"::/Apps/ToTheFront\");Dir;View;\n"$ -$LK,"::/Demo/Graphics/SpriteText.CC"$ -$LK,"::/Demo/Graphics/SpriteRaw.CC"$ +$LK,"::/Demo/Graphics/SpriteText.ZC"$ +$LK,"::/Demo/Graphics/SpriteRaw.ZC"$ $MA-X+PU,"::/Apps/GrModels",LM="Cd(\"::/Apps/GrModels\");Dir;View;\n"$ $MA-X+PU,"::/Apps/KeepAway",LM="Cd(\"::/Apps/KeepAway\");Dir;View;\n"$ -$LK,"::/Demo/Games/Rocket.CC"$ -$LK,"::/Demo/Games/RocketScience.CC"$ -$LK,"::/Demo/Games/MassSpring.CC"$ -$LK,"::/Demo/Graphics/LightTable.CC"$ -$LK,"::/Demo/Games/Whap.CC"$ -$LK,"::/Demo/Games/Squirt.CC"$ +$LK,"::/Demo/Games/Rocket.ZC"$ +$LK,"::/Demo/Games/RocketScience.ZC"$ +$LK,"::/Demo/Games/MassSpring.ZC"$ +$LK,"::/Demo/Graphics/LightTable.ZC"$ +$LK,"::/Demo/Games/Whap.ZC"$ +$LK,"::/Demo/Games/Squirt.ZC"$ $MA-X+PU,"::/Apps/X-Caliber",LM="Cd(\"::/Apps/X-Caliber\");Dir;View;\n"$ -$LK,"::/Demo/Games/ZoneOut.CC"$ -$LK,"::/Demo/Games/CastleFrankenstein.CC"$ -$LK,"::/Demo/Games/Talons.CC"$ +$LK,"::/Demo/Games/ZoneOut.ZC"$ +$LK,"::/Demo/Games/CastleFrankenstein.ZC"$ +$LK,"::/Demo/Games/Talons.ZC"$ $MA-X+PU,"::/Apps/Strut",LM="Cd(\"::/Apps/Strut\");Dir;View;\n"$ $MA-X+PU,"::/Apps/Span",LM="Cd(\"::/Apps/Span\");Dir;View;\n"$ $MA-X+PU,"::/Apps/Psalmody",LM="Cd(\"::/Apps/Psalmody\");Dir;View;\n"$ $ID,-2$$TR,"Non-Game"$ -$ID,2$$LK,"::/Misc/DoDistro.CC"$ -$LK,"::/Demo/DebugDemo.CC"$ -$LK,"::/Demo/SubSwitch.CC"$ -$LK,"::/Demo/DateTime.CC"$ -$LK,"::/Demo/RevFileDemo/Rev.CC"$ -$LK,"::/Demo/ToHtmlToTXTDemo/HtmlGen.CC"$ -$LK,"::/Demo/ToHtmlToTXTDemo/TXTGen.CC"$ -$LK,"::/Demo/SortFileDemo/F64FileGen.CC"$ -$LK,"::/Demo/SortFileDemo/F64FileSort.CC"$ -$LK,"::/Demo/PhoneNumWords.CC"$ -$LK,"::/Demo/SuggestSpelling.CC"$ -$LK,"::/Demo/WordSearch.CC"$ -$LK,"::/Demo/Graphics/CommonAncestor.CC"$ -$LK,"::/Demo/Directives.CC"$ -$LK,"::/Demo/Carry.CC"$ -$LK,"::/Demo/Disk/DataBase.CC"$ -$LK,"::/Demo/Disk/FPrintF.CC"$ -$LK,"::/Demo/Disk/DiskRaw.CC"$ -$LK,"::/Demo/Disk/UnusedSpaceRep.CC"$ -$LK,"::/Demo/Lectures/MiniGrLib.CC"$ -$LK,"::/Demo/Lectures/MiniCompiler.CC"$ -$LK,"::/Demo/MagicPairs.CC"$ -$LK,"::/Demo/Graphics/PoleZeros.CC"$ -$LK,"::/Demo/WebLogDemo/WebLogRep.CC"$ -$LK,"::/Demo/WebLogDemo/WebLogScramble.CC"$ +$ID,2$$LK,"::/Misc/DoDistro.ZC"$ +$LK,"::/Demo/DebugDemo.ZC"$ +$LK,"::/Demo/SubSwitch.ZC"$ +$LK,"::/Demo/DateTime.ZC"$ +$LK,"::/Demo/RevFileDemo/Rev.ZC"$ +$LK,"::/Demo/ToHtmlToTXTDemo/HtmlGen.ZC"$ +$LK,"::/Demo/ToHtmlToTXTDemo/TXTGen.ZC"$ +$LK,"::/Demo/SortFileDemo/F64FileGen.ZC"$ +$LK,"::/Demo/SortFileDemo/F64FileSort.ZC"$ +$LK,"::/Demo/PhoneNumWords.ZC"$ +$LK,"::/Demo/SuggestSpelling.ZC"$ +$LK,"::/Demo/WordSearch.ZC"$ +$LK,"::/Demo/Graphics/CommonAncestor.ZC"$ +$LK,"::/Demo/Directives.ZC"$ +$LK,"::/Demo/Carry.ZC"$ +$LK,"::/Demo/Disk/DataBase.ZC"$ +$LK,"::/Demo/Disk/FPrintF.ZC"$ +$LK,"::/Demo/Disk/DiskRaw.ZC"$ +$LK,"::/Demo/Disk/UnusedSpaceRep.ZC"$ +$LK,"::/Demo/Lectures/MiniGrLib.ZC"$ +$LK,"::/Demo/Lectures/MiniCompiler.ZC"$ +$LK,"::/Demo/MagicPairs.ZC"$ +$LK,"::/Demo/Graphics/PoleZeros.ZC"$ +$LK,"::/Demo/WebLogDemo/WebLogRep.ZC"$ +$LK,"::/Demo/WebLogDemo/WebLogScramble.ZC"$ $MA-X+PU,"::/Apps/TimeClock",LM="Cd(\"::/Apps/TimeClock\");Dir;View;\n"$ $MA-X+PU,"::/Apps/Logic",LM="Cd(\"::/Apps/Logic\");Dir;View;\n"$ $MA-X+PU,"::/Demo/Lectures",LM="Cd(\"::/Demo/Lectures\");Dir;View;\n"$ $MA-X+PU,"::/Apps/Budget",LM="Cd(\"::/Apps/Budget\");Dir;View;\n"$ $ID,-2$$TR,"ZealOS Specific"$ $ID,2$$MA-X+PU,"::/Demo/InFile",LM="Cd(\"::/Demo/InFile\");Dir;View;\n"$ -$LK,"::/Demo/Print.CC"$ -$LK,"::/Demo/SubIntAccess.CC"$ -$LK,"::/Demo/ParenWarn.CC"$ -$LK,"::/Demo/NullCase.CC"$ -$LK,"::/Demo/OnceDemo.CC"$ -$LK,"::/Demo/CompileDemo.CC"$ -$LK,"::/Demo/Prompt.CC"$ -$LK,"::/Demo/ClassMeta.CC"$ -$LK,"::/Demo/LastClass.CC"$ -$LK,"::/Demo/DolDoc/NumBible.CC"$ -$LK,"::/Demo/DolDoc/Form.CC"$ -$LK,"::/Demo/DolDoc/MenuBttn.CC"$ -$LK,"::/Demo/DolDoc/MenuSprite.CC"$ -$LK,"::/Demo/DolDoc/ClickCallBack.CC"$ -$LK,"::/Demo/DolDoc/TreeDemo.CC"$ -$LK,"::/Demo/Exceptions.CC"$ -$LK,"::/Demo/Disk/SerializeTree.CC"$ -$LK,"::/Demo/MemDemo.CC"$ -$LK,"::/Demo/StackGrow.CC"$ -$LK,"::/Demo/DolDoc/TextDemo.CC"$ -$LK,"::/Demo/DolDoc/CursorMove.CC"$ +$LK,"::/Demo/Print.ZC"$ +$LK,"::/Demo/SubIntAccess.ZC"$ +$LK,"::/Demo/ParenWarn.ZC"$ +$LK,"::/Demo/NullCase.ZC"$ +$LK,"::/Demo/OnceDemo.ZC"$ +$LK,"::/Demo/CompileDemo.ZC"$ +$LK,"::/Demo/Prompt.ZC"$ +$LK,"::/Demo/ClassMeta.ZC"$ +$LK,"::/Demo/LastClass.ZC"$ +$LK,"::/Demo/DolDoc/NumBible.ZC"$ +$LK,"::/Demo/DolDoc/Form.ZC"$ +$LK,"::/Demo/DolDoc/MenuBttn.ZC"$ +$LK,"::/Demo/DolDoc/MenuSprite.ZC"$ +$LK,"::/Demo/DolDoc/ClickCallBack.ZC"$ +$LK,"::/Demo/DolDoc/TreeDemo.ZC"$ +$LK,"::/Demo/Exceptions.ZC"$ +$LK,"::/Demo/Disk/SerializeTree.ZC"$ +$LK,"::/Demo/MemDemo.ZC"$ +$LK,"::/Demo/StackGrow.ZC"$ +$LK,"::/Demo/DolDoc/TextDemo.ZC"$ +$LK,"::/Demo/DolDoc/CursorMove.ZC"$ $LK,"::/Demo/DolDoc/DemoDoc.DD"$ -$LK,"::/Demo/Spy.CC"$ -$LK,"::/Demo/DolDoc/FileRead.CC"$ -$LK,"::/Demo/DolDoc/Data.CC"$ -$LK,"::/Demo/DolDoc/DefineStr.CC"$ -$LK,"::/Demo/DolDoc/CallBack.CC"$ -$LK,"::/Demo/Define.CC"$ +$LK,"::/Demo/Spy.ZC"$ +$LK,"::/Demo/DolDoc/FileRead.ZC"$ +$LK,"::/Demo/DolDoc/Data.ZC"$ +$LK,"::/Demo/DolDoc/DefineStr.ZC"$ +$LK,"::/Demo/DolDoc/CallBack.ZC"$ +$LK,"::/Demo/Define.ZC"$ $LK,"EdRenumAsm",A="MN:EdRenumAsm"$ -$LK,"::/Demo/DolDoc/UnusedDefine.CC"$ -$LK,"::/Demo/Asm/AsmHelloWorld.CC"$ -$LK,"::/Demo/Asm/BuzzFizz.CC"$ -$LK,"::/Demo/Asm/PutDec.CC"$ -$LK,"::/Demo/Asm/MulByHand.CC"$ -$LK,"::/Demo/Asm/DivByHand.CC"$ -$LK,"::/Demo/Asm/AsmAndC1.CC"$ -$LK,"::/Demo/Asm/AsmAndC2.CC"$ -$LK,"::/Demo/Asm/AsmAndC3.CC"$ -$LK,"::/Demo/GlobalVars.CC"$ -$LK,"::/Misc/OSTestSuite.CC"$ +$LK,"::/Demo/DolDoc/UnusedDefine.ZC"$ +$LK,"::/Demo/Asm/AsmHelloWorld.ZC"$ +$LK,"::/Demo/Asm/BuzzFizz.ZC"$ +$LK,"::/Demo/Asm/PutDec.ZC"$ +$LK,"::/Demo/Asm/MulByHand.ZC"$ +$LK,"::/Demo/Asm/DivByHand.ZC"$ +$LK,"::/Demo/Asm/AsmAndC1.ZC"$ +$LK,"::/Demo/Asm/AsmAndC2.ZC"$ +$LK,"::/Demo/Asm/AsmAndC3.ZC"$ +$LK,"::/Demo/GlobalVars.ZC"$ +$LK,"::/Misc/OSTestSuite.ZC"$ $MA-X+PU,"::/System",LM="Cd(\"::/System\");Dir;View;\n"$ $ID,-2$ diff --git a/src/Doc/Directives.DD b/src/Doc/Directives.DD index e911490e..d821358b 100755 --- a/src/Doc/Directives.DD +++ b/src/Doc/Directives.DD @@ -5,4 +5,4 @@ $HL,1$$WW,0$#define __DATE__ #exe{StreamPrint("\"%D\"", Now);} #define __FILE__ #exe{StreamPrint("\"%s\"", Fs->last_cc->lex_include_stack->full_name);} #define __DIR__ #exe{StreamDir;} -See $LK,"::/Demo/Directives.CC"$.$HL,0$$WW,1$ +See $LK,"::/Demo/Directives.ZC"$.$HL,0$$WW,1$ diff --git a/src/Doc/DolDocOverview.DD b/src/Doc/DolDocOverview.DD index aa50affa..6e4d6817 100755 --- a/src/Doc/DolDocOverview.DD +++ b/src/Doc/DolDocOverview.DD @@ -4,18 +4,18 @@ DolDoc is a ZealOS document type supported by $LK,"DolDoc Routines",A="HI:DolDoc Here is the grammar: - := $FG,2$$$$FG$<$LK,"TwoLetterCmd",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_CMDS"$>[][$FG,2$,$FG$]$FG,2$$$$FG$ | $FG,2$$$$FG$$LK,"ColorName",A="MN:ST_COLORS"$$FG,2$$$$FG$ + := $FG,2$$$$FG$<$LK,"TwoLetterCmd",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_CMDS"$>[][$FG,2$,$FG$]$FG,2$$$$FG$ | $FG,2$$$$FG$$LK,"ColorName",A="MN:ST_COLORS"$$FG,2$$$$FG$ - := $FG,2$+$FG$|$FG,2$-$FG$ <$LK,"FlagCode",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$>[$FG$] + := $FG,2$+$FG$|$FG,2$-$FG$ <$LK,"FlagCode",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$>[$FG$] - := <$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$>$FG,2$=$FG$[$FG,2$,$FG$] + := <$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$>$FG,2$=$FG$[$FG,2$,$FG$] -The format of DolDoc cmds is a two character code, +/-flags, a comma and args separated by commas. Some commands have mandatory args. Optional args are indicated with <$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$>$FG,2$=$FG$. A $LK,"ColorName",A="MN:ST_COLORS"$ bracked by dollars, will change the foreground color. +The format of DolDoc cmds is a two character code, +/-flags, a comma and args separated by commas. Some commands have mandatory args. Optional args are indicated with <$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$>$FG,2$=$FG$. A $LK,"ColorName",A="MN:ST_COLORS"$ bracked by dollars, will change the foreground color. -See $LK,"::/Doc/Widget.DD"$, $LK,"::/Demo/DolDoc/DemoDoc.DD"$, and $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +See $LK,"::/Doc/Widget.DD"$, $LK,"::/Demo/DolDoc/DemoDoc.DD"$, and $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. -<$LK,"TwoLetterCmd",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_CMDS"$> See $LK,"Type Defines",A="MN:DOCT_TEXT"$ and $LK,"ParseDollarCmd",A="MN:ParseDollarCmd"$(). +<$LK,"TwoLetterCmd",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_CMDS"$> See $LK,"Type Defines",A="MN:DOCT_TEXT"$ and $LK,"ParseDollarCmd",A="MN:ParseDollarCmd"$(). $TR,"TX Text"$ $ID,2$Normally, text is not bracketed with '$FG,2$$$$FG$', but if you wish to specify flag attr, such as centering text, you can bracket them with '$FG,2$$$$FG$' and enter flags such as "$FG,2$+CX$FG$". You can't edit them normally if they are bracketed by '$FG,2$$$$FG$' unless you toggle to plain text mode with $FG,2$$FG$. $ID,-2$$TR,"CR Hard New Line"$ @@ -95,7 +95,7 @@ The expressions are relative to the current cursor location, unless you make the $FG,2$+BY$FG$ bottom $FG,2$+PRY$FG$ page relative -See $LK,"::/Demo/DolDoc/CursorMove.CC"$. +See $LK,"::/Demo/DolDoc/CursorMove.ZC"$. $ID,-2$$TR,"AN Anchor"$ $ID,2$The $LK,"CDocEntry",A="MN:CDocEntry"$.aux_str arg $FG,2$A=""$FG$ is used for the anchor. Terry didn't use these very often, but they're good sometimes. @@ -120,11 +120,11 @@ Examples: to see 12) For in-memory document address links, see $LK,"SpriteEdText",A="MN:SpriteEdText"$(). $ID,-2$$TR,"BT Button"$ -$ID,2$See $LK,"::/Demo/DolDoc/MenuBttn.CC"$. +$ID,2$See $LK,"::/Demo/DolDoc/MenuBttn.ZC"$. $ID,-2$$TR,"DA Data"$ -$ID,2$Used for forms that prompt for data or just displaying a value. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.CC"$, $LK,"::/Demo/Disk/DataBase.CC"$, and $LK,"::/System/DolDoc/DocWidgetWiz.CC"$. +$ID,2$Used for forms that prompt for data or just displaying a value. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.ZC"$, $LK,"::/Demo/Disk/DataBase.ZC"$, and $LK,"::/System/DolDoc/DocWidgetWiz.ZC"$. -If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$DA...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the $FG,2$->data$FG$ address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.CC,&Fs->task_title"$. +If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$DA...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the $FG,2$->data$FG$ address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.ZC,&Fs->task_title"$. The default raw data type for the $FG,2$$$DA...$$$FG$ command is $FG,2$RT=I64$FG$. $LK,"DocForm",A="MN:DocForm"$() will automatically reset the raw type to the value from the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's definition if you leave it set to the default. Or, if not using $LK,"DocForm",A="MN:DocForm"$(), specify a raw data type of $FG,2$I8$FG$, $FG,2$U8$FG$, $FG,2$I16$FG$, $FG,2$U16$FG$, $FG,2$I32$FG$, $FG,2$U32$FG$, $FG,2$I64$FG$, $FG,2$U64$FG$, or $FG,2$F64$FG$. See $LK,"DocDataFormat",A="MN:DocDataFormat"$() and $LK,"DocDataScan",A="MN:DocDataScan"$(). @@ -132,17 +132,17 @@ The $LK,"CDocEntry",A="MN:CDocEntry"$.aux_str arg $FG,2$A=""$FG$ is used for the The default field length is $FG,2$LEN=64$FG$ characters. For U8 arrays[], $LK,"DocForm",A="MN:DocForm"$() will automatically reset the field length to the string length from the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's definition. The length measures starting after the ':' in the $FG,2$A=""$FG$ format string. -The space after the first ':' in the format string marks the first valid cursor pos. See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$. +The space after the first ':' in the format string marks the first valid cursor pos. See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$. $ID,-2$$TR,"CB Check Box"$ -$ID,2$Used for forms. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.CC"$$FG$ and $LK,"CEdFindText",A="MN:CEdFindText"$. +$ID,2$Used for forms. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.ZC"$$FG$ and $LK,"CEdFindText",A="MN:CEdFindText"$. -If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$CB...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the $FG,2$->data$FG$ address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.CC,&Fs->task_title"$. +If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$CB...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the $FG,2$->data$FG$ address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.ZC,&Fs->task_title"$. The default raw data type for the $FG,2$$$CB...$$$FG$ command is $FG,2$RT=I8$FG$ which is $FG,2$Bool$FG$. $LK,"DocForm",A="MN:DocForm"$() will automatically reset the raw type to the value from the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's definition if you leave it set to the default. Or, if not using $LK,"DocForm",A="MN:DocForm"$(), specify a raw data type of $FG,2$I8$FG$, $FG,2$U8$FG$, $FG,2$I16$FG$, $FG,2$U16$FG$, $FG,2$I32$FG$, $FG,2$U32$FG$, $FG,2$I64$FG$, $FG,2$U64$FG$, or $FG,2$F64$FG$. See $LK,"DocDataFormat",A="MN:DocDataFormat"$() and $LK,"DocDataScan",A="MN:DocDataScan"$(). $ID,-2$$TR,"LS List Widget"$ -$ID,2$Used for forms that prompt for data. You must specify a define list, $FG,2$D=""$FG$. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.CC"$. +$ID,2$Used for forms that prompt for data. You must specify a define list, $FG,2$D=""$FG$. Use $FG,2$$FG$ to help you generate the DolDoc command text you need in your $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's $FG,2$format$FG$ meta-data for $LK,"DocForm",A="MN:DocForm"$(). See $LK,"::/Demo/DolDoc/Form.ZC"$. -If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$LS...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the data address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.CC,&Fs->task_title"$. +If you are not using $LK,"DocForm",A="MN:DocForm"$(), make a $FG,2$$$LS...$$$FG$ statement with $LK,"DocPrint",A="MN:DocPrint"$() and fill-in the data address. See $LK,"task_title",A="FF:::/System/DolDoc/DocEd.ZC,&Fs->task_title"$. The default raw data type for the $FG,2$$$LS...$$$FG$ command is $FG,2$RT=I64$FG$. $LK,"DocForm",A="MN:DocForm"$() will automatically reset the raw type to the value from the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's definition if you leave it set to the default. Or, if not using $LK,"DocForm",A="MN:DocForm"$(), specify a raw data type of $FG,2$I8$FG$, $FG,2$U8$FG$, $FG,2$I16$FG$, $FG,2$U16$FG$, $FG,2$I32$FG$, $FG,2$U32$FG$, $FG,2$I64$FG$, $FG,2$U64$FG$, or $FG,2$F64$FG$. See $LK,"DocDataFormat",A="MN:DocDataFormat"$() and $LK,"DocDataScan",A="MN:DocDataScan"$(). $ID,-2$$TR,"MA Macro"$ @@ -162,7 +162,7 @@ $ID,2$A tree widget is a branch in a collapsable tree. The domain of the branch You might want to use $LK,"DocPrintAtomic",A="MN:DocPrintAtomic"$(). -See $LK,"::/Demo/DolDoc/TreeDemo.CC"$. +See $LK,"::/Demo/DolDoc/TreeDemo.ZC"$. $ID,-2$$TR,"SP Sprite"$ $ID,2$Insert a sprite into text with $FG,2$$FG$. The cursor location at the time you press $FG,2$$FG$ is critical because the sprite will be offset from that location. This is important when adding images to programs. Numbers for sprites are automatically chosen because copying to and from the clip requires this. You can insert another sprite with the same image by hitting $FG,2$$FG$ and manually adding a $FG,2$$$SP...$$$FG$ entry with the same $FG,2$BI=$FG$ num. @@ -172,7 +172,7 @@ $ID,2$Tells the compiler to insert a pointer to some binary data stored after th You can, optionally, include tag text to be displayed for the $FG,2$$$IB...$$$FG$ cmd. If you set the tag to "<1>", then the editor will automatically update the tag if the $FG,2$BI=$FG$ number changes. -The reason for the $FG,2$$$IB...$$$FG$ cmd is to pass a arg to $LK,"Sprite",A="MN:Sprite"$() and $LK,"Sprite3",A="MN:Sprite3"$(). See $LK,"::/Demo/Graphics/SpritePlot.CC"$. +The reason for the $FG,2$$$IB...$$$FG$ cmd is to pass a arg to $LK,"Sprite",A="MN:Sprite"$() and $LK,"Sprite3",A="MN:Sprite3"$(). See $LK,"::/Demo/Graphics/SpritePlot.ZC"$. $ID,-2$$TR,"IS Insert Binary Size"$ $ID,2$Inserts a number into the compiled stream describing the size of binary data associated with a bin number. Terry never used this. @@ -183,11 +183,11 @@ $ID,2$Include a $FG,2$1$FG$ or $FG,2$0$FG$. $FG,2$$$HL,1$$$FG$ will turn syntax highlighting on. $ID,-2$$TR,"HC html"$ -$ID,2$See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$ to generate a html version of a document. You can cause html code to be injected with $FG,2$HC$FG$. Use the $FG,2$+HTML$FG$ flag to inject a html link. +$ID,2$See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$ to generate a html version of a document. You can cause html code to be injected with $FG,2$HC$FG$. Use the $FG,2$+HTML$FG$ flag to inject a html link. $ID,-2$$TR,"ER Error"$ $ID,2$When errors are detected in DolDoc cmds, an $FG,2$ER$FG$ entry is generated. $ID,-2$ -<$LK,"FlagCode",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$> See $LK,"Flag Defines",A="MN:DOCEf_LEFT_CB"$ and $LK,"Simple Flags",A="FI:::/Doc/Widget.DD"$. +<$LK,"FlagCode",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$> See $LK,"Flag Defines",A="MN:DOCEf_LEFT_CB"$ and $LK,"Simple Flags",A="FI:::/Doc/Widget.DD"$. $TR,"+H Hold"$ $ID,2$Causes not to delete this cmd when cleared with $FG,2$CL$FG$ or when the doc->max_entries is exceeded. Word wrap is a good to hold. There is no way to delete these entries, at this point. $ID,-2$$TR,"+L Link"$ @@ -213,39 +213,39 @@ $ID,2$The Refresh Data flag on a $FG,2$DA$FG$ or a $FG,2$CB$FG$ makes the value $ID,-2$$TR,"+UD Update Data"$ $ID,2$The Update Data flag on a $FG,2$DA$FG$ or a $FG,2$CB$FG$ makes the value in the $LK,"CDocEntry",A="MN:CDocEntry"$ updated when keys are typed on it. $ID,-2$$TR,"+TC Tag CallBack"$ -$ID,2$See $LK,"::/Demo/DolDoc/CallBack.CC"$. +$ID,2$See $LK,"::/Demo/DolDoc/CallBack.ZC"$. $ID,-2$$TR,"+LC Left CallBack"$ -$ID,2$See $LK,"::/Demo/DolDoc/ClickCallBack.CC"$. +$ID,2$See $LK,"::/Demo/DolDoc/ClickCallBack.ZC"$. $ID,-2$$TR,"+RC Right CallBack"$ -$ID,2$See $LK,"::/Demo/DolDoc/ClickCallBack.CC"$. +$ID,2$See $LK,"::/Demo/DolDoc/ClickCallBack.ZC"$. $ID,-2$ -<$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.CC,ST_DOC_FLAGS"$> See $LK,"Arg Defines",A="MN:DOCEf_TAG"$. +<$LK,"ArgCode",A="FF:::/System/DolDoc/DocInit.ZC,ST_DOC_FLAGS"$> See $LK,"Arg Defines",A="MN:DOCEf_TAG"$. $TR,"T=\"\" Tag Str"$ -$ID,2$Some cmds have a tag by default. See $LK,"TX+T",A="FF:::/System/DolDoc/DocInit.CC,TX+T"$. You can code $FG,2$T="tag_text"$FG$ as just $FG,2$"tag_text"$FG$ with no $FG,2$T=$FG$. +$ID,2$Some cmds have a tag by default. See $LK,"TX+T",A="FF:::/System/DolDoc/DocInit.ZC,TX+T"$. You can code $FG,2$T="tag_text"$FG$ as just $FG,2$"tag_text"$FG$ with no $FG,2$T=$FG$. $ID,-2$$TR,"LEN=\"\" Field Length"$ $ID,2$The default field length for $FG,2$$$DA...$$$FG$ commands is $FG,2$LEN=64$FG$ characters. For U8 arrays[], $LK,"DocForm",A="MN:DocForm"$() will automatically reset the field length to the string length from the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ $FG,2$class$FG$ member's definition. The length measures starting after the ':' in the $FG,2$A=""$FG$ format string. -The space after the first ':' in the format string marks the first valid cursor pos. See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$. +The space after the first ':' in the format string marks the first valid cursor pos. See $LK,"Data Tag Width",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$. $ID,-2$$TR,"A=\"\" Auxilliary Str"$ $ID,2$Some cmds need auxilliary strings. $FG,2$A="str"$FG$ means an $LK,"CDocEntry",A="MN:CDocEntry"$.aux_str is present. aux_str is used for song note text, link text, anchor text, and $FG,2$$$DA...$$$FG$ format string text. $ID,-2$$TR,"D=\"\" Define Str"$ $ID,2$A $FG,2$D=""$FG$ means either a $LK,"define",A="HI:Define"$ str indirection is present on a text widget, or a define list is present on a list widget. -For indirection, the tag will be regenerated by substituting the value of a system $FG,2$#define$FG$ or $LK,"DefineLoad",A="MN:DefineLoad"$() string. See $LK,"::/Demo/DolDoc/DefineStr.CC"$, $LK,"::/System/Define.CC"$ and $LK,"::/Doc/MemoryOverview.DD"$. +For indirection, the tag will be regenerated by substituting the value of a system $FG,2$#define$FG$ or $LK,"DefineLoad",A="MN:DefineLoad"$() string. See $LK,"::/Demo/DolDoc/DefineStr.ZC"$, $LK,"::/System/Define.ZC"$ and $LK,"::/Doc/MemoryOverview.DD"$. -For $FG,2$LS$FG$ widgets, see $LK,"::/Demo/DolDoc/Form.CC"$. +For $FG,2$LS$FG$ widgets, see $LK,"::/Demo/DolDoc/Form.ZC"$. $ID,-2$$TR,"HTML=\"\""$ -$ID,2$See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$ to generate a html version of a document. You can cause html link on an item with $FG,2$HTML=""$FG$. +$ID,2$See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$ to generate a html version of a document. You can cause html link on an item with $FG,2$HTML=""$FG$. $ID,-2$$TR,"LE= Left Expression"$ $ID,2$Left expression. $FG,2$CM$FG$ has this by default for X offset and you can leave-off the $FG,2$LE=$FG$, just putting the $FG,2$$FG$. -See $LK,"::/Demo/DolDoc/MenuBttn.CC"$. +See $LK,"::/Demo/DolDoc/MenuBttn.ZC"$. $ID,-2$$TR,"LM=\"\" Left Macro Str"$ $ID,2$Left macro string. $ID,-2$$TR,"RE= Right Expression"$ $ID,2$Right expression. $FG,2$CM$FG$ has this by default for Y offset and you can leave-off the $FG,2$RE=$FG$, just putting the $FG,2$$FG$. -See $LK,"::/Demo/DolDoc/MenuBttn.CC"$. +See $LK,"::/Demo/DolDoc/MenuBttn.ZC"$. $ID,-2$$TR,"RM=\"\" Right Macro Str"$ $ID,2$Right macro string. $ID,-2$$TR,"BI= Bin Number"$ @@ -254,7 +254,7 @@ $ID,-2$$TR,"BP=\"\" Bin Pointer"$ $ID,2$The BinPtrLink flags lets you specify a filename and bin num to import a bin$FG$. $FG,2$$$SP,"",BI=1,BP="filename,1"$$$FG$ will import bin num "1" from filename. -$FG,2$$$SP,"<1>",BI=1,BP="::/Demo/Graphics/Mountain.CC,Mountain"$$$FG$ will import bin with tag name "Mountain" from "::/Demo/Graphics/Mountain.CC". +$FG,2$$$SP,"<1>",BI=1,BP="::/Demo/Graphics/Mountain.ZC,Mountain"$$$FG$ will import bin with tag name "Mountain" from "::/Demo/Graphics/Mountain.ZC". $ID,-2$$TR,"RT="$ $ID,2$The default data-type for the $FG,2$$$DA...$$$FG$ and $FG,2$$$LS...$$$FG$ commands is $FG,2$RT=I64$FG$. If you do not specify a raw type and are using $LK,"DocForm",A="MN:DocForm"$(), it will use the $FG,2$class$FG$ member's raw type, automatically. The default for the $FG,2$$$CB...$$$FG$ command is $FG,2$RT=I8$FG$ which is $FG,2$Bool$FG$. @@ -268,7 +268,7 @@ $ID,2$Scroll text in a marquee of so many columns. $ID,-2$$TR,"U= User Data"$ $ID,2$User Data. -See $LK,"::/Demo/DolDoc/MenuBttn.CC"$. +See $LK,"::/Demo/DolDoc/MenuBttn.ZC"$. $ID,-2$ $FG,5$EXAMPLES: diff --git a/src/Doc/FAQ.DD b/src/Doc/FAQ.DD index 1ce2e7ab..c5cfb763 100755 --- a/src/Doc/FAQ.DD +++ b/src/Doc/FAQ.DD @@ -27,7 +27,7 @@ $ID,2$$LK,"Yield",A="MN:Yield"$() saves the current task's registers (context) a $ID,-2$$TR,"What is JIT Compiled Mode?"$ $ID,2$The term $LK,"JIT Compile Mode",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$ means it compiles and executes code placed into mem, not stored on disk. $ID,-2$$TR,"Is it open source? How do I build it?"$ -$ID,2$ZealOS is 100% open source. All the source code is included in the distro. Use $LK,"BootHDIns",A="MN:BootHDIns"$() to compile the kernel and compiler. The rest is $LK,"JIT Compiled",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$ during boot. See $LK,"::/StartOS.CC"$. +$ID,2$ZealOS is 100% open source. All the source code is included in the distro. Use $LK,"BootHDIns",A="MN:BootHDIns"$() to compile the kernel and compiler. The rest is $LK,"JIT Compiled",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$ during boot. See $LK,"::/StartOS.ZC"$. $ID,-2$$TR,"Where are object files? How do I link?"$ $ID,2$ZealOS does not use object files or a linker. $LK,"AOT Compile Mode",A="FF:::/Doc/Glossary.DD,AOT Compile Mode"$ is used to directly create flat binary files, $LK,"::/Boot/Kernel.BIN.C",A="FI:::/Kernel/Kernel.PRJ"$ and $LK,"::/Compiler/Compiler.BIN",A="FI:::/Compiler/Compiler.PRJ"$ with no object files and linking.$FG$ $LK,"JIT Compile Mode",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$ place code in memory, ready to run, with no object files or linking. Linking is done when $FG,2$BIN$FG$ modules are $LK,"Load",A="MN:Load"$()ed. $ID,-2$$TR,"What is the FPS refresh rate?"$ @@ -39,7 +39,7 @@ $ID,2$ZealOS allocs mem as more items are displayed in the window. Also, ZealOS $ID,-2$$TR,"Why do I get a memory leak when editing big files?"$ $ID,2$The editor periodically takes a snap-shot of the document for $FG,2$UNDO$FG$ and this looks like a memory leak. $ID,-2$$TR,"Why is it in text mode?"$ -$ID,2$ZealOS runs in $FG,2$High-res 32-bit color VBE$FG$ graphics modes, not text mode. It changes to this mode with a $LK,"BIOS call",A="FF:::/Kernel/KStart16.CC,INT:9"$ while in real-mode before it switches to 64-bit mode. The text is $LK,"drawn by hand",A="MN:GrUpdateTextFG"$. See $LK,"::/Kernel/FontStd.CC"$. +$ID,2$ZealOS runs in $FG,2$High-res 32-bit color VBE$FG$ graphics modes, not text mode. It changes to this mode with a $LK,"BIOS call",A="FF:::/Kernel/KStart16.ZC,INT:9"$ while in real-mode before it switches to 64-bit mode. The text is $LK,"drawn by hand",A="MN:GrUpdateTextFG"$. See $LK,"::/Kernel/FontStd.ZC"$. $ID,-2$$TR,"Where is the kernel memory?"$ $ID,2$ZealOS identity-maps all memory, all the time. It is like paging is not used. There is no special kernel $FG,2$high half$FG$ memory space. ZealOS is ring-0-only, so everything is kernel, even user programs. There is a special task called $FG,2$System$FG$ and it doesn't die, so its heap never gets freed. That's as close to $FG,2$kernel memory$FG$ as it gets. All code goes in the lowest 2Gig of addresses, known as the $LK,"Code Heap",A="FF:::/Doc/Glossary.DD,Code and Data Heaps"$, so that the $FG,2$REL32$FG$ addressing mode can be used. See $LK,"MemoryOverview",A="FI:::/Doc/MemoryOverview.DD"$. $ID,-2$$TR,"Why does it run code from stack addresses?"$ @@ -51,11 +51,11 @@ $ID,2$The stack does not grow, so do not do deep recursion. In theory, memory g $ID,-2$$TR,"How do I set the PATH?"$ $ID,2$There is no $FG,2$PATH$FG$. You do not enter filenames at the command-line and expect them to run. You enter C-like code. $LK,"Get Started Here",A="FI:::/Doc/CmdLineOverview.DD"$. $ID,-2$$TR,"How do I boot it with Grub?"$ -$ID,2$If you use Grub, you $FG,2$chain-load$FG$ like Windows. See $LK,"Boot",A="FI:::/Doc/Boot.DD"$. You can use the ZealOS boot-loader. $LK,"Master-Boot-Loader-Stage1",A="FI:::/System/Boot/BootMHD.CC"$, $LK,"Master-Boot-Loader-Stage2",A="FI:::/System/Boot/BootMHD2.CC"$, $LK,"Partition-Boot-Loader",A="FI:::/System/Boot/BootHD.CC"$, $LK,"CD-DVD-Boot-Loader",A="FI:::/System/Boot/BootDVD.CC"$. +$ID,2$If you use Grub, you $FG,2$chain-load$FG$ like Windows. See $LK,"Boot",A="FI:::/Doc/Boot.DD"$. You can use the ZealOS boot-loader. $LK,"Master-Boot-Loader-Stage1",A="FI:::/System/Boot/BootMHD.ZC"$, $LK,"Master-Boot-Loader-Stage2",A="FI:::/System/Boot/BootMHD2.ZC"$, $LK,"Partition-Boot-Loader",A="FI:::/System/Boot/BootHD.ZC"$, $LK,"CD-DVD-Boot-Loader",A="FI:::/System/Boot/BootDVD.ZC"$. $ID,-2$$TR,"How do I get Kernel.BIN to boot?"$ -$ID,2$The boot-loaders must be patched by you running $LK,"BootHDIns",A="MN:BootHDIns"$() or $LK,"BootMHDIns",A="MN:BootMHDIns"$(). Those will write the block address into the boot-loader because the boot-loaders do not navigate file systems to find the $LK,"Stage2",A="FI:::/Kernel/KStart16.CC"$ if you relocate it. +$ID,2$The boot-loaders must be patched by you running $LK,"BootHDIns",A="MN:BootHDIns"$() or $LK,"BootMHDIns",A="MN:BootMHDIns"$(). Those will write the block address into the boot-loader because the boot-loaders do not navigate file systems to find the $LK,"Stage2",A="FI:::/Kernel/KStart16.ZC"$ if you relocate it. $ID,-2$$TR,"Why is there some 16-Bit code?"$ -$ID,2$ZealOS is 64-bit. Like all PC operating systems, the boot-loader starts in 16-bit real-mode. ZealOS calls a few $FG,2$BIOS$FG$ info routines, switches to VGA-640x480x4bit, switches to 32-bit, then, 64-bit mode. There is an odd thing called a $FG,2$$TX,"PCI BIOS",HTML="http://www.o3one.org/hwdocs/bios_doc/pci_bios_21.pdf"$$FG$ which is 32-bit used for $FG,2$PCI$FG$ config space access. If supported, ZealOS calls $LK,"that",A="FI:::/Kernel/PCIBIOS.CC"$ a couple times, otherwise using Port I/O for PCI. It must temporarily drop-out-of 64-bit mode for that and stop multi-tasking. +$ID,2$ZealOS is 64-bit. Like all PC operating systems, the boot-loader starts in 16-bit real-mode. ZealOS calls a few $FG,2$BIOS$FG$ info routines, switches to VGA-640x480x4bit, switches to 32-bit, then, 64-bit mode. There is an odd thing called a $FG,2$$TX,"PCI BIOS",HTML="http://www.o3one.org/hwdocs/bios_doc/pci_bios_21.pdf"$$FG$ which is 32-bit used for $FG,2$PCI$FG$ config space access. If supported, ZealOS calls $LK,"that",A="FI:::/Kernel/PCIBIOS.ZC"$ a couple times, otherwise using Port I/O for PCI. It must temporarily drop-out-of 64-bit mode for that and stop multi-tasking. $ID,-2$$TR,"Why are you pushing 32-bit values on the stack?"$ $ID,2$$FG,2$PUSH EAX$FG$ : All stack operations in 64-bit mode are 64-bits. $ID,-2$$TR,"Why are you using 32-bit insts and not setting high 32-bits?"$ @@ -79,7 +79,7 @@ $ID,2$Binary sprite data is stored beyond the terminating $FG,2$NULL$FG$ in text $ID,-2$$TR,"Why are sprites so small?"$ $ID,2$Sprites can be stored as vector graphics so they might take shockingly little room. They can be converted to bitmaps. $ID,-2$$TR,"Why don't I need to recompile /System and /Home files?"$ -$ID,2$If you change code in the $FG,2$/System$FG$ or your $FG,2$/Home$FG$ directory, you don't need to recompile, you just need to reboot because those directories get recompiled when you boot. It uses $LK,"JIT Compile Mode",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$. There is no $FG,2$.BIN$FG$ file for $FG,2$JIT$FG$ compilation. See $LK,"::/StartOS.CC"$. +$ID,2$If you change code in the $FG,2$/System$FG$ or your $FG,2$/Home$FG$ directory, you don't need to recompile, you just need to reboot because those directories get recompiled when you boot. It uses $LK,"JIT Compile Mode",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$. There is no $FG,2$.BIN$FG$ file for $FG,2$JIT$FG$ compilation. See $LK,"::/StartOS.ZC"$. $ID,-2$$TR,"Why does it finds files that aren't there?"$ $ID,2$If a file is not found, the parent directories are searched for a file of the same name. $ID,-2$ diff --git a/src/Doc/FileMgr.DD b/src/Doc/FileMgr.DD index 59c4b0d9..989c33c7 100755 --- a/src/Doc/FileMgr.DD +++ b/src/Doc/FileMgr.DD @@ -62,5 +62,5 @@ $ID,-2$ $FG,5$Instructions on Burning CD/DVD's$FG$ $ID,2$Create a temporary dir to hold files and copy files into the holding dir. Make an ISO image of the dir by pressing $FG,2$'M'$FG$ when on top of the dir. Press $FG,2$'B'$FG$ when on top of the CD/DVD ROM drive to burn the ISO, $FG,2$$TX,"\"::/Tmp/CDDVD.ISO\"",D="DEFAULT_ISO_FILENAME"$$FG$ $LK,"blkdev.default_iso_filename",A="MN:CBlkDevGlobals"$, to disk. If you have not recompiled $FG,2$Kernel$FG$ and defined your CD/DVD drive, exit the FileMgr and use $LK,"Mount",A="MN:Mount"$. -$LK,"Making Your Own Distro",A="FI:::/Misc/DoDistro.CC"$ +$LK,"Making Your Own Distro",A="FI:::/Misc/DoDistro.ZC"$ $ID,-2$ \ No newline at end of file diff --git a/src/Doc/Frame.DD b/src/Doc/Frame.DD index feae01b9..16521d71 100755 --- a/src/Doc/Frame.DD +++ b/src/Doc/Frame.DD @@ -1 +1 @@ -$WW,1$If you require separate global variables for multiple instances of a routine, you can use $FG,4$Frame$FG$s. See $LK,"SpriteMeshEd",A="MN:SpriteMeshEd"$(), $LK,"::/Demo/Graphics/Pick3D.CC"$ or $LK,"Noise",A="MN:Noise"$(). +$WW,1$If you require separate global variables for multiple instances of a routine, you can use $FG,4$Frame$FG$s. See $LK,"SpriteMeshEd",A="MN:SpriteMeshEd"$(), $LK,"::/Demo/Graphics/Pick3D.ZC"$ or $LK,"Noise",A="MN:Noise"$(). diff --git a/src/Doc/Glossary.DD b/src/Doc/Glossary.DD index d224c6cd..021f2a12 100755 --- a/src/Doc/Glossary.DD +++ b/src/Doc/Glossary.DD @@ -147,7 +147,7 @@ $ID,2$There is no distinction between $FG,2$task$FG$, $FG,2$process$FG$ or $FG,2 Since there is not friendly disk sharing and all tasks have the same address map, it might be accurate to call ZealOS, "multi-thread/single-process". You run a single application process on $FG,2$Core0$FG$ and it can create threads on the same core or others. If you run multiple processes, it should be safe, but one process will wait until another completely finishes a long disk access. $ID,-2$$TR,"System Task"$ -$ID,2$The System task is immortal. The system task is created at start-up and appears in the small window at the top beneath the user terminal windows. Since the System task is immortal, on its heap go all memory objects which you don't want destroyed by any single task's death. When created, the System task runs the file $LK,"::/StartOS.CC"$. When start-up is finished, the system task enters a server mode where it accepts requests from other tasks. The $LK,"Sys",A="MN:Sys"$("") routine will make the System task compile and run text src code. $FG,2$#include$FG$ statements can be sent to $LK,"Sys",A="MN:Sys"$(""), creating system-wide code and data which are immortal. +$ID,2$The System task is immortal. The system task is created at start-up and appears in the small window at the top beneath the user terminal windows. Since the System task is immortal, on its heap go all memory objects which you don't want destroyed by any single task's death. When created, the System task runs the file $LK,"::/StartOS.ZC"$. When start-up is finished, the system task enters a server mode where it accepts requests from other tasks. The $LK,"Sys",A="MN:Sys"$("") routine will make the System task compile and run text src code. $FG,2$#include$FG$ statements can be sent to $LK,"Sys",A="MN:Sys"$(""), creating system-wide code and data which are immortal. $ID,-2$$TR,"Executive Tasks"$ $ID,2$Each CPU core has an $FG,2$Executive$FG$ task that is immortal. The System task on $FG,2$Core0$FG$ is also its $FG,2$Executive$FG$ task. $ID,-2$$TR,"Code and Data Heaps"$ @@ -205,8 +205,8 @@ $ID,2$$FG,5$$FG,5$*.???.C$FG$ Contiguous files - not fragmented on disk. $FG,5$*.DD$FG$ Text Files -$FG,5$*.CC$FG$ - ZealC src files. The default ZealC compiler type is $FG,2$.CC$FG$. +$FG,5$*.ZC$FG$ + ZealC src files. The default ZealC compiler type is $FG,2$.ZC$FG$. $FG,5$*.PRJ$FG$ ZealC src files to be compiled $FG,2$AOT$FG$. $FG,5$*.HH$FG$ diff --git a/src/Doc/GraphicsOverview.DD b/src/Doc/GraphicsOverview.DD index de096af260605214064e267816845eab626509b0..32edddf4b79c7dce49f8ad85ea1ab8f7fb74e32e 100755 GIT binary patch delta 104 zcmZ2vy2y0HNk+z~&8HaeG6AU-EU!Sk$!zPGIHH`DR1^~PQYOoDDzX^6=tXVL$FG$, insert a macro with the PopUp option checked and invoke the $FG,2$Run.CC$FG$ file. +$FG,2$/Apps$FG$ Applications are placed in subdirectories of $FG,2$/Apps$FG$. Applications should have a file called $FG,2$Install.ZC$FG$ which will install the app, possibly making files or directories in $FG,2$/Home$FG$. The file, $FG,2$Load.ZC$FG$ will load the application into mem. The file, $FG,2$Run.ZC$FG$, will usually load and execute the app. To add an app to your PersonalMenu, use $FG,2$$FG$, insert a macro with the PopUp option checked and invoke the $FG,2$Run.ZC$FG$ file. $FG,2$/Demo$FG$ Here you can find lots of sample code to do various things. @@ -26,13 +26,13 @@ $LK,"~/PersonalMenu.DD"$ a menu viewed with the $FG,2$$FG$ key or by cli $LK,"~/PersonalNotes.DD"$ a personal note file viewed with the $FG,2$$FG$ key. -$LK,"~/MakeHome.CC"$ a file compiled by the $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ during $LK,"StartOS",A="FF:::/StartOS.CC,MakeHome"$. +$LK,"~/MakeHome.ZC"$ a file compiled by the $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ during $LK,"StartOS",A="FF:::/StartOS.ZC,MakeHome"$. $FG,4$~/Home*$FG$ Copy $FG,2$Home*$FG$ files from the root into $FG,2$~$FG$ and customize them. These files are invoked when the $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ starts-up. -$LK,"~/Once.CC"$ a file invoked at the start-up of the first user. Customize this! +$LK,"~/Once.ZC"$ a file invoked at the start-up of the first user. Customize this! -$LK,"~/Registry.CC"$ can be edited by hand or deleted to reset to defaults. Takes affect next boot. +$LK,"~/Registry.ZC"$ can be edited by hand or deleted to reset to defaults. Takes affect next boot. @@ -40,13 +40,13 @@ $FG,5$$TX+CX,"Application Policies"$$FG$ * Place applications in their own $FG,2$/Apps$FG$ subdirectory. -* Make a file called $FG,2$Load.CC$FG$ to load the application. +* Make a file called $FG,2$Load.ZC$FG$ to load the application. -* Make a file called $FG,2$Run.CC$FG$ to load and run the application, preferable by $FG,2$#include$FG$ing the $FG,2$Load.CC$FG$ file. +* Make a file called $FG,2$Run.ZC$FG$ to load and run the application, preferable by $FG,2$#include$FG$ing the $FG,2$Load.ZC$FG$ file. -* Place user data in a subdirectory of $FG,2$/Home$FG$, preferably naming the subdirectory the same as the $FG,2$/Apps$FG$ subdirectory. Or, place data in the $FG,2$Registry.CC$FG$ file. See $LK,"::/Demo/RegistryDemo.CC"$. +* Place user data in a subdirectory of $FG,2$/Home$FG$, preferably naming the subdirectory the same as the $FG,2$/Apps$FG$ subdirectory. Or, place data in the $FG,2$Registry.ZC$FG$ file. See $LK,"::/Demo/RegistryDemo.ZC"$. -* If the app needs files in the $FG,2$/Home$FG$ directory, make an $FG,2$/Apps$FG$ file called $FG,2$Install.CC$FG$ or $FG,2$Install.IN$FG$ to create the $FG,2$/Home$FG$ subdirectory. +* If the app needs files in the $FG,2$/Home$FG$ directory, make an $FG,2$/Apps$FG$ file called $FG,2$Install.ZC$FG$ or $FG,2$Install.IN$FG$ to create the $FG,2$/Home$FG$ subdirectory. @@ -92,7 +92,7 @@ $ID,-5$ $FG,5$$TX+CX,"Hash Sym Tables"$$FG$ -* See $LK,"::/System/Hash.CC"$ for examples of how the hash tables are set-up. Basically, symbols are placed into hash tables and child process hash tables are chained to parents. This provides scopes for variables and functions. +* See $LK,"::/System/Hash.ZC"$ for examples of how the hash tables are set-up. Basically, symbols are placed into hash tables and child process hash tables are chained to parents. This provides scopes for variables and functions. * $FG,2$sys_task->hash_table$FG$ holds the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ symbols loaded in on start-up. diff --git a/src/Doc/Hash.DD b/src/Doc/Hash.DD index 14065d192ccf0988bf09e64f90400c92a42f500d..6f65aaf33e4deb385ee5c022c1b15482e1908ad8 100755 GIT binary patch delta 20 ccmdlaut{LURwl-%$=jGr7^617W^!i*08hdP4FCWD delta 20 ccmdlaut{LURwhR0$=jGr7@ar2W^!i*08S(Z-v9sr diff --git a/src/Doc/HelloWorld.DD b/src/Doc/HelloWorld.DD index 1bea496c..15249dbe 100755 --- a/src/Doc/HelloWorld.DD +++ b/src/Doc/HelloWorld.DD @@ -1,10 +1,10 @@ $HL,1$//Press F5 in the editor to compile and run. -// --------Hello.CC--------- // +// --------Hello.ZC--------- // "Hello World\n"; -// --------Hello.CC--------- // +// --------Hello.ZC--------- // U0 Main() { "Hello World\n"; @@ -12,7 +12,7 @@ U0 Main() Main; -// --------Hello.CC--------- // +// --------Hello.ZC--------- // U0 MyPrint(U8 *st) { "%s", st; @@ -20,7 +20,7 @@ U0 MyPrint(U8 *st) MyPrint("Hello World\n"); -// --------Hello.CC--------- // +// --------Hello.ZC--------- // U0 MyPrint2(U8 *st1, U8 *st2) //Any number of args. { "%s %s\n", st1, st2; //Any number of args. @@ -28,7 +28,7 @@ U0 MyPrint2(U8 *st1, U8 *st2) //Any number of args. MyPrint2("Hello", "World"); -// --------Hello.CC--------- // +// --------Hello.ZC--------- // U0 MyPrint(U8 *st) { "" st; //Empty with no comma means first is format str. @@ -36,7 +36,7 @@ U0 MyPrint(U8 *st) MyPrint("Hello World\n"); -// --------Hello.CC--------- // +// --------Hello.ZC--------- // asm { MESSAGE: DU8 "Hello World\n", 0; @@ -53,7 +53,7 @@ _HELLO_WORLD1:: Call(_HELLO_WORLD1); -// --------Hello.CC--------- // +// --------Hello.ZC--------- // asm { _HELLO_WORLD2:: //You can only clobber RAX,RBX,RCX,RDX @@ -66,7 +66,7 @@ _HELLO_WORLD2:: Call(_HELLO_WORLD2); -// --------Hello.CC--------- // +// --------Hello.ZC--------- // asm { _MY_PRINT1:: //You can only clobber RAX,RBX,RCX,RDX @@ -83,7 +83,7 @@ _extern _MY_PRINT1 U0 MyPrint(U8 *st); MyPrint("Hello World\n"); - // --------Hello.CC--------- // + // --------Hello.ZC--------- // asm { _MY_PRINT2:: //You can only clobber RAX,RBX,RCX,RDX diff --git a/src/Doc/HelpIndex.DD b/src/Doc/HelpIndex.DD index fc3e8e8cd7483e752bbb1b52115b0bd11e827ef3..1ce81d38cb7add5ec33d9946a380775d735ef9b4 100755 GIT binary patch delta 211 zcmdmHy3KUMcTUEr%|AG$85yG{i*P#u$#Cv^AbFkpja-zok_wlKkGGDJPik^WX;Esi zzGGgBUw(;ieu`eyrC(Wmcr71mtJtm4MYqO}69Z1{&zaD+MGU@<>gt=j8yh zI(X%w{8_xbK-L9b1t9s6R|DuCDLxjEdq9dU`T2k>4}LEoIhkJzNbcj;2a@mj&4Hwv RfHjaz63_u^>K9Pw0s#1sK*az6 delta 211 zcmdmHy3KUMcTPs<%|AG$85x}?i*P#u$#Cv^AbFkpjhwTyk_wlKkGGDJPik^WX;Esi zzGGgBUw(;ieu|#+rC(Wmcr71mtJtm4MYqO}69Z1{&zaD+MGU@<>gt=j8yh zI(X%w{8_xbK-L9b1t9s6R|DuCDLxjEdq9dU`T2k>4}LEoIhkJzNbcj;2a@mj&4Hwv RfHjaz63_u^>K9Pw0suH;KC}P; diff --git a/src/Doc/Install.DD b/src/Doc/Install.DD index 08572c48..3de69f78 100755 --- a/src/Doc/Install.DD +++ b/src/Doc/Install.DD @@ -4,7 +4,7 @@ Burn a CD with software that supports ISO files. Then, boot it. It's a live CD, Dual booting with another operating system is the best way to use ZealOS. It is often used in a virtual machine because it won't boot natively on some machines, though. For native dual booting, you need a partition for ZealOS. Windows often comes with a restore disk that does not allow repartitioning. It's recommended to connect a spare additional hard drive and use the $FG,2$BIOS$FG$ to select which drive to boot. -The $LK,"::/Misc/OSInstall.CC"$ script will automate much of this. It runs if you boot the CD/DVD-ROM. +The $LK,"::/Misc/OSInstall.ZC"$ script will automate much of this. It runs if you boot the CD/DVD-ROM. See $LK,"Boot.DD",A="FI:::/Doc/Boot.DD"$ for an overview of booting. See $LK,"Requirements",A="FI:::/Doc/Requirements.DD"$ for supported hardware. diff --git a/src/Doc/KeyDev.DD b/src/Doc/KeyDev.DD index 756d9142..11b360db 100755 --- a/src/Doc/KeyDev.DD +++ b/src/Doc/KeyDev.DD @@ -11,4 +11,4 @@ $FG,2$0x80000000$FG$ $LK,"KDDocPutKey",A="MN:KDDocPutKey"$() standard document c Since handling individual keys is slow, ZealOS supports PutS() as well. If no puts handler is defined, individual keys are sent. -$LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_key$FG$ and $LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_s$FG$ are call back routines which offer some neat tricks. See $LK,"::/Apps/Psalmody/JukeBox.CC"$. There is a variable $LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_data$FG$ which gets passed to them. +$LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_key$FG$ and $LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_s$FG$ are call back routines which offer some neat tricks. See $LK,"::/Apps/Psalmody/JukeBox.ZC"$. There is a variable $LK,"CDoc",A="MN:CDoc"$$FG,2$.user_put_data$FG$ which gets passed to them. diff --git a/src/Doc/Lex.DD b/src/Doc/Lex.DD index e9043a3a..f6e99fa6 100755 --- a/src/Doc/Lex.DD +++ b/src/Doc/Lex.DD @@ -1,3 +1,3 @@ -$WW,1$The compiler's lexical analyzer can be used in your programs to simplify parsing. See $LK,"Doc Parsing",A="FF:::/System/DolDoc/DocPlain.CC,CompCtrlNew"$ or $LK,"Parse Opcode File",A="FF:::/Compiler/AsmInit.CC,Opcodes.DD"$. +$WW,1$The compiler's lexical analyzer can be used in your programs to simplify parsing. See $LK,"Doc Parsing",A="FF:::/System/DolDoc/DocPlain.ZC,CompCtrlNew"$ or $LK,"Parse Opcode File",A="FF:::/Compiler/AsmInit.ZC,Opcodes.DD"$. See $LK,"Tokens",A="MN:TK_IDENT"$. diff --git a/src/Doc/MemoryOverview.DD b/src/Doc/MemoryOverview.DD index ea8e2e8f..a8172059 100755 --- a/src/Doc/MemoryOverview.DD +++ b/src/Doc/MemoryOverview.DD @@ -8,11 +8,11 @@ You can create new, independent heaps using $LK,"HeapCtrlInit",A="MN:HeapCtrlIni Memory alloced by a task will be freed when the task is killed. The $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ is a task that never dies. Its memory is like kernel memory in other operating systems. See $LK,"SysCAlloc",A="MN:SysCAlloc"$(), $LK,"SysMAlloc",A="MN:SysMAlloc"$(), $LK,"SysMAllocIdent",A="MN:SysMAllocIdent"$() and $LK,"SysStrNew",A="MN:SysStrNew"$(). -All of the regular page tables are marked, "cached". When accessing hardware, however, you need uncached page table. The lowest 4Gig addresses have an alias to access hardware located toward the top of mapped space, $FG,2$0x$TX,"01D7800000",D="DD_UNCACHED_ALIAS"$$FG$. See $LK,"dev.uncached_alias",A="FF:::/Kernel/MultiProc.CC,dev.uncached_alias"$. +All of the regular page tables are marked, "cached". When accessing hardware, however, you need uncached page table. The lowest 4Gig addresses have an alias to access hardware located toward the top of mapped space, $FG,2$0x$TX,"01D7800000",D="DD_UNCACHED_ALIAS"$$FG$. See $LK,"dev.uncached_alias",A="FF:::/Kernel/MultiProc.ZC,dev.uncached_alias"$. During an extended powered-on session of ZealOS, in theory, memory will become fragmented, requiring a reboot. It has never happens to me. -See $LK,"MemRep",A="MN:MemRep"$() and $LK,"::/Demo/MemDemo.CC"$. +See $LK,"MemRep",A="MN:MemRep"$() and $LK,"::/Demo/MemDemo.ZC"$. $FG,5$$TX+CX,"Single System-wide Memory Map"$ @@ -21,7 +21,7 @@ $FG,2$ 0x00$TX,"00007C00",D="DD_KERNEL"$- 0x00$TX,"000370BF",D="DD_KERNEL_END"$$ $ID,2$Kernel module, placed here by the boot-loader, $LK,"BOOT_RAM_BASE",A="MN:BOOT_RAM_BASE"$. $ID,-2$ $FG,2$ 0x00$TX,"00096600",D="DD_BOOT_HIGH_LOC_DVD"$- 0x00$TX,"00096FFF",D="DD_BOOT_HIGH_LOC_DVD_END"$$FG$ -$ID,2$$FG$Boot block relocated here before loading the Kernel module, $LK,"BootDVD",A="FI:::/System/Boot/BootDVD.CC"$ & $LK,"BootHD",A="FI:::/System/Boot/BootHD.CC"$. +$ID,2$$FG$Boot block relocated here before loading the Kernel module, $LK,"BootDVD",A="FI:::/System/Boot/BootDVD.ZC"$ & $LK,"BootHD",A="FI:::/System/Boot/BootHD.ZC"$. $ID,-2$ $FG,2$ 0x00$TX,"00097000",D="DD_MP_VECT"$- 0x00$TX,"0009703B",D="DD_MP_VECT_END"$$FG$ Multicore start-up vect code, $LK,"MPN_VECT",A="MN:MPN_VECT"$. $FG,2$~0x000009F000- 0x000009FFFF$FG$ Extended BIOS data area. @@ -55,8 +55,8 @@ In 2003, Terry Davis wanted to make a no-paging ring-0-only 64-bit operating sys Terry needed VGA A0000-BFFFF memory to be write-through and 0xE0000000-0xFFFFFFFF to be uncached for various devices. All 64-bit computers allow stopping address translation at 2Meg page size, not using 4K. He wanted to use 2Meg for everything because it's faster, with one less level of page tables. He had to make A0000-BFFFF write-through, though, so he could not use 2Meg size on the lowest page. He did the lowest 2Meg area as 4K pages. He also unmapped the first 4K to cause a fault when dereferencing NULL. -In 2016, Terry came-up with an alternate idea. He double mapped the lowest memory with an alias that was uncached. Accessing the lowest 2Meg area directly was cached but the alias he created up at the top of address space was uncached. See $LK,"UncachedAliasAlloc",A="MN:UncachedAliasAlloc"$(). Unfortunately, he could no longer boast of the simplicity of identity mapping everything. Since many of the users are familiar with A0000-BFFFF, it is actually pretty seriously unfortunate that they cannot use the easy-to-understand numbers of A0000-BFFFF, but must access the relocated alias location. See $LK,"text.vga_alias",A="FF:::/Kernel/KMain.CC,text.vga_alias"$. We also no longer cause a fault when dereferencing NULL. +In 2016, Terry came-up with an alternate idea. He double mapped the lowest memory with an alias that was uncached. Accessing the lowest 2Meg area directly was cached but the alias he created up at the top of address space was uncached. See $LK,"UncachedAliasAlloc",A="MN:UncachedAliasAlloc"$(). Unfortunately, he could no longer boast of the simplicity of identity mapping everything. Since many of the users are familiar with A0000-BFFFF, it is actually pretty seriously unfortunate that they cannot use the easy-to-understand numbers of A0000-BFFFF, but must access the relocated alias location. See $LK,"text.vga_alias",A="FF:::/Kernel/KMain.ZC,text.vga_alias"$. We also no longer cause a fault when dereferencing NULL. Then, Terry switched to 1Gig page sizes. For the lowest 4Gig, he set-up an alias up at the top of address space. See $LK,"UncachedAliasAlloc",A="MN:UncachedAliasAlloc"$(). Not all computers support 1Gig page tables, however, so he also supported 2Meg. -Terry's original plan was to allow changing the page tables as needed, so he had code for taking control of 2Meg pages and marking them uncached or whatever. When he did an HDAudio driver, he requested some 32-bit address space as uncached. Today, all of the first 4Gig can be accessed without caching at the $LK,"dev.uncached_alias",A="FF:::/Kernel/MultiProc.CC,dev.uncached_alias"$. +Terry's original plan was to allow changing the page tables as needed, so he had code for taking control of 2Meg pages and marking them uncached or whatever. When he did an HDAudio driver, he requested some 32-bit address space as uncached. Today, all of the first 4Gig can be accessed without caching at the $LK,"dev.uncached_alias",A="FF:::/Kernel/MultiProc.ZC,dev.uncached_alias"$. diff --git a/src/Doc/Menus.DD b/src/Doc/Menus.DD index 8f5c087b..e9c8578d 100755 --- a/src/Doc/Menus.DD +++ b/src/Doc/Menus.DD @@ -25,4 +25,4 @@ The first arg is the message code and it is optional with the default being $LK, Press $FG,2$$FG$ and "Insert ASCII/ScanCode". -See $LK,"::/Demo/PullDownMenu.CC"$. +See $LK,"::/Demo/PullDownMenu.ZC"$. diff --git a/src/Doc/Mouse.DD b/src/Doc/Mouse.DD index 928669e6..9c7eb6a2 100755 --- a/src/Doc/Mouse.DD +++ b/src/Doc/Mouse.DD @@ -1,6 +1,6 @@ $WW,1$$LK,"mouse.pos.x",A="MN:mouse"$ and $LK,"mouse.pos.y",A="MN:mouse"$ can be used to access the x and y coordinates of the mouse. They are relative to the screen, not window. These can be used if you don't want to use message passing. $LK,"mouse.pos.z",A="MN:mouse"$ is the wheel. -$LK,"mouse.pos_text.x",A="MN:CMouseStateGlobals"$ and $LK,"mouse.pos_text.y",A="MN:CMouseStateGlobals"$ are the text column and row. See $LK,"::/Demo/Games/Maze.CC"$. +$LK,"mouse.pos_text.x",A="MN:CMouseStateGlobals"$ and $LK,"mouse.pos_text.y",A="MN:CMouseStateGlobals"$ are the text column and row. See $LK,"::/Demo/Games/Maze.ZC"$. See $LK,"CMouseStateGlobals",A="MN:CMouseStateGlobals"$ and $LK,"CMouseHardStateGlobals",A="MN:CMouseHardStateGlobals"$. diff --git a/src/Doc/MultiCore.DD b/src/Doc/MultiCore.DD index f02b5d51..3aa714a9 100755 --- a/src/Doc/MultiCore.DD +++ b/src/Doc/MultiCore.DD @@ -1,6 +1,6 @@ $WW,1$ZealOS does master-slave multicore instead of SMP. $FG,2$Core0$FG$ is the master. The master core's applications explicitly assign computational jobs to other cores and the ZealOS scheduler does not move tasks between cores. -There are multicore safe locks for file access and heap allocations, however, so ZealOS is symmetrical in some sense. See $LK,"::/Demo/MultiCore/LoadTest.CC"$. +There are multicore safe locks for file access and heap allocations, however, so ZealOS is symmetrical in some sense. See $LK,"::/Demo/MultiCore/LoadTest.ZC"$. Only tasks on $FG,2$Core0$FG$ can have windows, but other cores can help render them. @@ -8,7 +8,7 @@ Each core has an $LK,"Executive Task",A="FF:::/Doc/Glossary.DD,Executive Tasks"$ You give a job to an $LK,"Executive Task",A="FF:::/Doc/Glossary.DD,Executive Tasks"$ with $LK,"JobQueue",A="MN:JobQueue"$() and get the result with $LK,"JobResGet",A="MN:JobResGet"$(). You spawn a task on any core with $LK,"Spawn",A="MN:Spawn"$(). -Note: You must use the $FG,2$LOCK$FG$ asm prefix when changing shared structures in a multicore environment. The $LK,"LBts",A="MN:LBts"$(), $LK,"LBtr",A="MN:LBtr"$() and $LK,"LBtc",A="MN:LBtc"$() insts have $FG,2$LOCK$FG$ prefixes. The compiler has a $FG,2$lock{}$FG$ feature but it doesn't work well. See $LK,"::/Demo/MultiCore/Lock.CC"$. +Note: You must use the $FG,2$LOCK$FG$ asm prefix when changing shared structures in a multicore environment. The $LK,"LBts",A="MN:LBts"$(), $LK,"LBtr",A="MN:LBtr"$() and $LK,"LBtc",A="MN:LBtc"$() insts have $FG,2$LOCK$FG$ prefixes. The compiler has a $FG,2$lock{}$FG$ feature but it doesn't work well. See $LK,"::/Demo/MultiCore/Lock.ZC"$. -See $LK,"::/Demo/Graphics/Transform.CC"$. -See $LK,"::/Kernel/MultiProc.CC"$. +See $LK,"::/Demo/Graphics/Transform.ZC"$. +See $LK,"::/Kernel/MultiProc.ZC"$. diff --git a/src/Doc/ODE.DD b/src/Doc/ODE.DD index aa9a24cc..262ee1aa 100755 --- a/src/Doc/ODE.DD +++ b/src/Doc/ODE.DD @@ -3,4 +3,4 @@ $WW,1$ZealOS has an advanced algorithm for integrating ordinary differential equ See $LK,"CMathODE",A="MN:CMathODE"$ and $LK,"ODEsUpdate",A="MN:ODEsUpdate"$ for an overview. See $LK,"ODECallDerivative",A="MN:ODECallDerivative"$ to see what support there is for masses and springs. -See $LK,"::/Demo/Games/Whap.CC"$, $LK,"::/Demo/Games/Rocket.CC"$, $LK,"::/Demo/Games/MassSpring.CC"$, $LK,"::/Apps/Span/SpanMain.CC"$ or $LK,"::/Apps/X-Caliber/X-Caliber.CC"$. +See $LK,"::/Demo/Games/Whap.ZC"$, $LK,"::/Demo/Games/Rocket.ZC"$, $LK,"::/Demo/Games/MassSpring.ZC"$, $LK,"::/Apps/Span/SpanMain.ZC"$ or $LK,"::/Apps/X-Caliber/X-Caliber.ZC"$. diff --git a/src/Doc/Once.DD b/src/Doc/Once.DD index f8763fae..4b234f02 100755 --- a/src/Doc/Once.DD +++ b/src/Doc/Once.DD @@ -1,14 +1,14 @@ $WW,1$$LK,"KMain",A="MN:KMain"$() - includes $LK,"::/StartOS.CC"$ - includes $LK,"~/MakeHome.CC"$ - includes $LK,"~/HomeSys.CC"$ - calls $LK,"StartUpTasks",A="FF:~/HomeSys.CC,StartUpTasks"$() - includes $LK,"~/Once.CC"$ + includes $LK,"::/StartOS.ZC"$ + includes $LK,"~/MakeHome.ZC"$ + includes $LK,"~/HomeSys.ZC"$ + calls $LK,"StartUpTasks",A="FF:~/HomeSys.ZC,StartUpTasks"$() + includes $LK,"~/Once.ZC"$ calls $LK,"OnceExe",A="MN:OnceExe"$(). -$LK,"SysOnce",A="MN:SysOnce"$() appends src code to $LK,"~/Registry.CC"$ $FG,2$Once/System$FG$ tree, executed at next boot by $FG,2$System$FG$. +$LK,"SysOnce",A="MN:SysOnce"$() appends src code to $LK,"~/Registry.ZC"$ $FG,2$Once/System$FG$ tree, executed at next boot by $FG,2$System$FG$. -$LK,"Once",A="MN:Once"$() appends src code to $LK,"~/Registry.CC"$ $FG,2$Once/User$FG$ tree, executed at next boot by first $FG,2$User$FG$ term. +$LK,"Once",A="MN:Once"$() appends src code to $LK,"~/Registry.ZC"$ $FG,2$Once/User$FG$ tree, executed at next boot by first $FG,2$User$FG$ term. At boot, $LK,"OnceExe",A="MN:OnceExe"$(), executes $FG,2$Once/System$FG$ tree, $LK,"SysOnceFlush",A="MN:SysOnceFlush"$()s it, executes $FG,2$Once/User$FG$ tree and $LK,"OnceFlush",A="MN:OnceFlush"$()s. diff --git a/src/Doc/PreProcessor.DD b/src/Doc/PreProcessor.DD index 6c8ac064..c2e9ad91 100755 --- a/src/Doc/PreProcessor.DD +++ b/src/Doc/PreProcessor.DD @@ -16,4 +16,4 @@ $FG,2$#ifaot,#ifjit $FG$Include code if in $FG,2$AOT$FG$ compiler mode. $FG,2$defined()$FG$ Is a function that can be used in expressions. $FG,2$#help_index$FG$, $FG,2$#help_file$FG$ See $LK,"Help System",A="FI:::/Doc/HelpSystem.DD"$. -See $LK,"PreProcessor",A="FF:::/Compiler/Lex.CC,KW_DEFINE"$. +See $LK,"PreProcessor",A="FF:::/Compiler/Lex.ZC,KW_DEFINE"$. diff --git a/src/Doc/Print.DD b/src/Doc/Print.DD index 4da760d3..d9a6609c 100755 --- a/src/Doc/Print.DD +++ b/src/Doc/Print.DD @@ -13,7 +13,7 @@ $FG,2$'/'$FG$ makes $FG,2$%Q$FG$ and $FG,2$%q$FG$ convert $FG,2$'%'$FG$ to $FG,2 $ID,-2$ : -$ID,2$For $FG,2$"%n"$FG$, $FG,2$"%d"$FG$ or $FG,2$"%u"$FG$, the causes thousands mode. $FG,2$"%h?n"$FG$ will pick a variable exponent multiples of three unit, while $FG,2$"%h-3n"$FG$ will display milli units or $FG,2$"%h6n"$FG$ will display mega units. The $FG,2$'k'$FG$ flag is always on for $FG,2$"%n"$FG$. See $LK,"::/Demo/Print.CC"$. +$ID,2$For $FG,2$"%n"$FG$, $FG,2$"%d"$FG$ or $FG,2$"%u"$FG$, the causes thousands mode. $FG,2$"%h?n"$FG$ will pick a variable exponent multiples of three unit, while $FG,2$"%h-3n"$FG$ will display milli units or $FG,2$"%h6n"$FG$ will display mega units. The $FG,2$'k'$FG$ flag is always on for $FG,2$"%n"$FG$. See $LK,"::/Demo/Print.ZC"$. For $FG,2$"%c"$FG$ or $FG,2$"%C"$FG$, the repeats the char that many times.$ID,-2$ @@ -66,7 +66,7 @@ $LK,"InStr",A="MN:InStr"$(U8 *format, ...) sends text of an $LK,"InFile",A="FF:: $LK,"XTalk",A="MN:XTalk"$(CTask *task, U8 *format, ...) and text to another task's input buffer. $LK,"XTalkStr",A="MN:XTalkStr"$(CTask *task, U8 *format, ...) sends text of an $LK,"InFile",A="FF:::/Doc/Glossary.DD,InFile"$ to the keyboard stream of another TASK but can also do mouse cmds. -$LK,"DocPrint",A="MN:DocPrint"$(CDoc *doc, U8 *format, ...) sends text to a document. You can buffer to a Doc and save it, providing the functionality of $FG,2$fprintf$FG$. See $LK,"::/Demo/Disk/FPrintF.CC"$. +$LK,"DocPrint",A="MN:DocPrint"$(CDoc *doc, U8 *format, ...) sends text to a document. You can buffer to a Doc and save it, providing the functionality of $FG,2$fprintf$FG$. See $LK,"::/Demo/Disk/FPrintF.ZC"$. $LK,"Sys",A="MN:Sys"$(U8 *format, ...) sends text to the $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ to be compiled and run. $LK,"SysLog",A="MN:SysLog"$(U8 *format, ...) and $LK,"SysErr",A="MN:SysErr"$(U8 *format,...) send text to the $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$ to be displayed. @@ -79,9 +79,9 @@ $LK,"TextPrint",A="MN:TextPrint"$(CTask *task, I64 x, I64 y, I64 attr, U8 *forma $LK,"ExePrint",A="MN:ExePrint"$(U8 *format, ...) compiles and execute a string. Note: It returns the res of the last executed expression. -$LK,"Once",A="MN:Once"$(U8 *format, ...) Writes User code to $LK,"Registry",A="FI:~/Registry.CC"$ to be executed next boot. +$LK,"Once",A="MN:Once"$(U8 *format, ...) Writes User code to $LK,"Registry",A="FI:~/Registry.ZC"$ to be executed next boot. -$LK,"SysOnce",A="MN:SysOnce"$(U8 *format, ...) Writes System code to $LK,"Registry",A="FI:~/Registry.CC"$ to be executed next boot. +$LK,"SysOnce",A="MN:SysOnce"$(U8 *format, ...) Writes System code to $LK,"Registry",A="FI:~/Registry.ZC"$ to be executed next boot. $LK,"InPrint",A="MN:InPrint"$(I64 mS, U8 *format, ...) $LK,"PutChars",A="MN:PutChars"$()s one at a time with a delay. diff --git a/src/Doc/RedSea.DD b/src/Doc/RedSea.DD index 1aba0989..9d54ded3 100755 --- a/src/Doc/RedSea.DD +++ b/src/Doc/RedSea.DD @@ -14,7 +14,7 @@ public class CDirEntry //64-byte fixed-size U8 name[CDIR_FILENAME_LEN]; //See $LK,"char_bmp_filename",A="MN:char_bmp_filename"$, $LK,"FileNameCheck",A="MN:FileNameCheck"$ I64 clus; $HL,0$$FG,7$(blk)$FG,0$$HL,1$ //One sector per cluster. I64 size; //In bytes - CDate datetime; //See $LK,"DateTime",A="::/Doc/TimeDate.DD"$, $LK,"Implementation of DateTime",A="FI:::/Kernel/KDate.CC"$ + CDate datetime; //See $LK,"DateTime",A="::/Doc/TimeDate.DD"$, $LK,"Implementation of DateTime",A="FI:::/Kernel/KDate.ZC"$ }; public class CRedSeaBoot //RedSea is type FAT32 in partition table to fool BIOS. @@ -30,7 +30,7 @@ public class CRedSeaBoot //RedSea is type FAT32 in partition table to fool BIOS. U16 signature2; //0xAA55 }; $HL,0$ -See $LK,"::/Kernel/BlkDev/FileSysRedSea.CC"$ and $LK,"::/System/Boot/DiskISORedSea.CC"$. +See $LK,"::/Kernel/BlkDev/FileSysRedSea.ZC"$ and $LK,"::/System/Boot/DiskISORedSea.ZC"$. To replace ISO9660, make hard-drive partition image of a measured size and copy onto a CD/DVD starting at about sector 20, with EL TORITO booting. 512-byte sectors will be placed on top of 2048-byte CD/DVD sectors, so there will be four blocks per CD/DVD sector. diff --git a/src/Doc/Sprite.DD b/src/Doc/Sprite.DD index a472dc7d..777c49b8 100755 --- a/src/Doc/Sprite.DD +++ b/src/Doc/Sprite.DD @@ -1,7 +1,7 @@ $WW,1$A $LK,"CSprite",A="MN:CSprite"$ is an ordered list of $LK,"these",A="MN:SPT_END"$ elements, created with $FG,2$$FG$. Normally, they are packed together in a list and the address of the first is passed to routines. -See $LK,"::/Demo/Graphics/SpritePlot.CC"$, $LK,"::/Demo/Graphics/SpritePlot3D.CC"$, $LK,"::/Demo/Graphics/SpritePut.CC"$, $LK,"::/Demo/Graphics/SpriteRaw.CC"$ and $LK,"SpriteMeshEd",A="MN:SpriteMeshEd"$(). +See $LK,"::/Demo/Graphics/SpritePlot.ZC"$, $LK,"::/Demo/Graphics/SpritePlot3D.ZC"$, $LK,"::/Demo/Graphics/SpritePut.ZC"$, $LK,"::/Demo/Graphics/SpriteRaw.ZC"$ and $LK,"SpriteMeshEd",A="MN:SpriteMeshEd"$(). Be aware that copying $FG,2$SP$FG$, $FG,2$IB$FG$, or $FG,2$IS$FG$ entries with the clip results in duplicate entries with different nums. You can manually remove dups by editing with $FG,2$$FG$ and setting to the original num. -See $LK,"::/System/Gr/GrSpritePlot.CC",A="FL:::/System/Gr/GrSpritePlot.CC,1"$ for how CSprite are stored.$FG$ +See $LK,"::/System/Gr/GrSpritePlot.ZC",A="FL:::/System/Gr/GrSpritePlot.ZC,1"$ for how CSprite are stored.$FG$ diff --git a/src/Doc/StdOutTask.DD b/src/Doc/StdOutTask.DD index 19872140..2eb55b15 100755 --- a/src/Doc/StdOutTask.DD +++ b/src/Doc/StdOutTask.DD @@ -1 +1 @@ -$WW,1$There is one $LK,"CDoc",A="MN:CDoc"$ for the task's border: $FG,2$Fs->border_doc$FG$. There is a pair for the task's client area: $FG,2$Fs->put_doc$FG$ and $FG,2$Fs->display_doc$FG$. You can, optionally, do double buffering, otherwise $FG,2$Fs->put_doc$FG$ is the same as $FG,2$Fs->display_doc$FG$. See $LK,"::/Demo/Spy.CC"$. +$WW,1$There is one $LK,"CDoc",A="MN:CDoc"$ for the task's border: $FG,2$Fs->border_doc$FG$. There is a pair for the task's client area: $FG,2$Fs->put_doc$FG$ and $FG,2$Fs->display_doc$FG$. You can, optionally, do double buffering, otherwise $FG,2$Fs->put_doc$FG$ is the same as $FG,2$Fs->display_doc$FG$. See $LK,"::/Demo/Spy.ZC"$. diff --git a/src/Doc/Strategy.DD b/src/Doc/Strategy.DD index f0e8afa7..53a2114f 100755 --- a/src/Doc/Strategy.DD +++ b/src/Doc/Strategy.DD @@ -40,7 +40,7 @@ A three button mouse is like a leg you cannot put weight on. ZealOS just does ha * No distinction between $FG,2$thread$FG$, $FG,2$process$FG$ or $FG,2$task$FG$. -* The $LK,"Scheduler",A="FI:::/Kernel/Sched.CC"$ is for home systems. It is not preemptiove. Disk requests are not broken-up, so sharing is bad. It's wonderfully simple. +* The $LK,"Scheduler",A="FI:::/Kernel/Sched.ZC"$ is for home systems. It is not preemptiove. Disk requests are not broken-up, so sharing is bad. It's wonderfully simple. * $LK,"MultiCore",A="FI:::/Doc/MultiCore.DD"$ is done $FG,2$master/slave$FG$, instead of $FG,2$SMP$FG$. $FG,2$Core0$FG$ applications explicitly assigns jobs. Locks are present allowing multicore file, heap, and hardware access, though. diff --git a/src/Doc/TextBase.DD b/src/Doc/TextBase.DD index 8422d084..d4e9eec8 100755 --- a/src/Doc/TextBase.DD +++ b/src/Doc/TextBase.DD @@ -12,4 +12,4 @@ Bit 31 $LK,"Underline",A="MN:ATTRF_UNDERLINE"$ $LK,"GrUpdateTaskWin",A="MN:GrUpdateTaskWin"$() calls $LK,"DocUpdateTaskDocs",A="MN:DocUpdateTaskDocs"$() which calls $LK,"DocRecalc",A="MN:DocRecalc"$() where the document text is plotted into $LK,"gr.text_base",A="MN:CGrGlobals"$. Then, $LK,"GrUpdateTextBG",A="MN:GrUpdateTextBG"$() and $LK,"GrUpdateTextFG",A="MN:GrUpdateTextFG"$() render the $LK,"gr.text_base",A="MN:CGrGlobals"$ onto $LK,"gr.dc2",A="MN:CGrGlobals"$, a raw graphic bitmap. -See $LK,"::/Demo/Games/Maze.CC"$. +See $LK,"::/Demo/Games/Maze.ZC"$. diff --git a/src/Doc/Tips.DD b/src/Doc/Tips.DD index de347039..eea22c8c 100755 --- a/src/Doc/Tips.DD +++ b/src/Doc/Tips.DD @@ -8,7 +8,7 @@ $WW,1$$FG,5$$TX+CX,"Tips"$$FG$ * See $MA-X+PU,"Key Map",LM="KeyMap;View;\n"$ for a list of defined keys. Define your own keys in $LK,"MyPutKey",A="MN:MyPutKey"$(). See $LK,"Keyboard Devices",A="HI:Keyboard Devices/System"$. -* $FG,2$$FG$ maximizes a window. $FG,2$$FG$ closes AutoComplete. $FG,2$$FG$ brings back AutoComplete. $FG,2$$FG$ vertically tiles windows. $FG,2$$FG$ horizontally tiles windows. The $FG,2$ALT$FG$ keys are defined in $LK,"~/HomeKeyPlugIns.CC"$. You can customize them. +* $FG,2$$FG$ maximizes a window. $FG,2$$FG$ closes AutoComplete. $FG,2$$FG$ brings back AutoComplete. $FG,2$$FG$ vertically tiles windows. $FG,2$$FG$ horizontally tiles windows. The $FG,2$ALT$FG$ keys are defined in $LK,"~/HomeKeyPlugIns.ZC"$. You can customize them. * If you make changes to ZealOS files in your $FG,2$/Home$FG$ directory, generally you reboot to make them take effect. (You don't compile anything.) You should have two ZealOS partitions on your hard drive because a syntax error in a start-up file will make the partition unbootable. Boot to the second partition or boot to a standard ZealOS CD/DVD and use $LK,"Mount",A="MN:Mount"$() to mount your hard drive. @@ -21,23 +21,23 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * Use the PullDown menu at the top of the screen to learn commands, or for finding the keyboard controls to games. -* You can adjust the mouse movement rate by setting global variables in your start-up file. See $LK,"mouse scale",A="FF:~/HomeLocalize.CC,mouse_hard.scale"$. +* You can adjust the mouse movement rate by setting global variables in your start-up file. See $LK,"mouse scale",A="FF:~/HomeLocalize.ZC,mouse_hard.scale"$. -* You can set your local time zone by setting the $LK,"local_time_offset",A="MN:local_time_offset"$ global variable in a start-up file. Its units are $LK,"CDATE_FREQ",A="MN:CDATE_FREQ"$. See $LK,"local time",A="FF:~/HomeLocalize.CC,local_time"$. +* You can set your local time zone by setting the $LK,"local_time_offset",A="MN:local_time_offset"$ global variable in a start-up file. Its units are $LK,"CDATE_FREQ",A="MN:CDATE_FREQ"$. See $LK,"local time",A="FF:~/HomeLocalize.ZC,local_time"$. * $FG,2$$FG$ in the editor to reindent a $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ function or renumber an asm routine's local labels. * You can use $FG,2$filter_lines$FG$ in the editor text search form ($FG,2$$FG$) to temporarily display just lines near each match. A value of $FG,2$filter lines$FG$ set to $FG,2$5$FG$ will display lines within 5 lines of matches. Then, you can do another find to a different string and achieve a $FG,2$AND$FG$ search. When finished, press $FG,2$$FG$. -* You can recompile and reinstall the kernel with $LK,"BootHDIns",A="MN:BootHDIns"$(). You'll probably want to make a function for recompiling that uses the $LK,"In",A="MN:In"$() function to answer the config questions. See the technique $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$. +* You can recompile and reinstall the kernel with $LK,"BootHDIns",A="MN:BootHDIns"$(). You'll probably want to make a function for recompiling that uses the $LK,"In",A="MN:In"$() function to answer the config questions. See the technique $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.ZC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.ZC,1"$. * $LK,"Scale2Mem",A="MN:Scale2Mem"$(min,max,limit=2*1024*1024*1024) can be used for config questions when recompiling. The $LK,"BootHDIns",A="MN:BootHDIns"$() config prompts accept expressions, not just numbers. The default disk cache is $FG,2$Scale2Mem(0x80000,0x8000000)$FG$. -* You can permanently disable $FG,2$AutoComplete$FG$ commenting-out $LK,"ACInit",A="FF:/Home/HomeSys.CC,ACInit"$() in $LK,"~/HomeSys.CC",A="FF:/Home/HomeSys.CC,ACInit"$. +* You can permanently disable $FG,2$AutoComplete$FG$ commenting-out $LK,"ACInit",A="FF:/Home/HomeSys.ZC,ACInit"$() in $LK,"~/HomeSys.ZC",A="FF:/Home/HomeSys.ZC,ACInit"$. * Boolean expressions $BK,1$not$BK,0$ in $FG,2$if$FG$ statements don't have short circuit logic and are compiled inefficiently. -* You can use $LK,"progress1",A="MN:progress1"$-$LK,"progress4",A="MN:progress4"$ in your programs for whatever you like. They're just global variables that are shown on the wallpaper. The original intent was to indicate how far along operations were. There's no coordination, so different apps might interfere. They're most often used for debugging--just values easily viewed. See $LK,"::/Demo/Progress.CC"$. +* You can use $LK,"progress1",A="MN:progress1"$-$LK,"progress4",A="MN:progress4"$ in your programs for whatever you like. They're just global variables that are shown on the wallpaper. The original intent was to indicate how far along operations were. There's no coordination, so different apps might interfere. They're most often used for debugging--just values easily viewed. See $LK,"::/Demo/Progress.ZC"$. * Use $LK,"DocMax",A="MN:DocMax"$() to adjust the size of the cmd line buf. It counts $LK,"CDoc",A="MN:CDoc"$ entries, not lines. @@ -53,7 +53,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * You can use $LK,"Option",A="MN:Option"$($LK,"OPTf_WARN_DUP_TYPES",A="MN:OPTf_WARN_DUP_TYPES"$, ON) to find unnecessary local variable type statements. -* $LK,"Option",A="MN:Option"$($LK,"OPTf_ECHO",A="MN:OPTf_ECHO"$, ON) can be placed in $LK,"StartOS.CC",A="FI:::/StartOS.CC"$ to echo start-up scripts. +* $LK,"Option",A="MN:Option"$($LK,"OPTf_ECHO",A="MN:OPTf_ECHO"$, ON) can be placed in $LK,"StartOS.ZC",A="FI:::/StartOS.ZC"$ to echo start-up scripts. * Use $LK,"Plain",A="MN:Plain"$() to edit a plain text file. You'll need this if your file has $FG,2$$$$FG$'s. Use the $LK,"ToDolDoc",A="MN:ToDolDoc"$() utility to convert plain text to DolDoc's by doubling $FG,2$$$$FG$'s. @@ -67,7 +67,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * Use $FG,2$$FG$ to enter an extended ASCII char. -* Use $FG,2$$FG$ to toggle between the $LK,"VGA ROM Font",A="FF:::/Kernel/KMain.CC,SYS_FONT_PTR:2"$ and $LK,"Std Font",A="FI:::/Kernel/FontStd.CC"$. +* Use $FG,2$$FG$ to toggle between the $LK,"VGA ROM Font",A="FF:::/Kernel/KMain.ZC,SYS_FONT_PTR:2"$ and $LK,"Std Font",A="FI:::/Kernel/FontStd.ZC"$. * Use $FG,2$$FG$ will capture the screen as a sprite on the clip. You can save the cmd line doc as text with $FG,2$$FG$. @@ -75,7 +75,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * You can eye-dropper colors in the $FG,2$$FG$ sprite editor by pressing $FG,2$'c'$FG$. Press $FG,2$'t'$FG$ for transparent. -* There are handy functions--$FG,2$F(),R(),FD()$FG$ and $FG,2$RD()$FG$ which are defined in $LK,"~/HomeWrappers.CC"$. You are encouraged to change them and add more. They will perform find-and-replace operations across multiple files. The $FG,2$+l$FG$ flag is particularly useful since it limits to whole labels. The $FG,2$+lb$FG$ and $FG,2$+la$FG$ flags limit to whole labels just before or after. You are encouraged to add or modify handy wrapper functions to make cmd line operations easier. +* There are handy functions--$FG,2$F(),R(),FD()$FG$ and $FG,2$RD()$FG$ which are defined in $LK,"~/HomeWrappers.ZC"$. You are encouraged to change them and add more. They will perform find-and-replace operations across multiple files. The $FG,2$+l$FG$ flag is particularly useful since it limits to whole labels. The $FG,2$+lb$FG$ and $FG,2$+la$FG$ flags limit to whole labels just before or after. You are encouraged to add or modify handy wrapper functions to make cmd line operations easier. * When using $LK,"Find",A="MN:Find"$() while modifying code, work from the bottom-up so that line numbers are correct. If you work top-down, then inserting or deleting lines causes the lower file links to become incorrect. @@ -83,7 +83,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * When using $FG,2$$FG$ to insert links in documents, you can usually leave the $FG,2$Tag Text$FG$ blank and it will be filled-in automatically based on other entries. -* There is a feature of the precompiler that allows code to be executed in the middle of compilation and data inserted into the compilation stream. Click here for an example: $LK,"#exe {",A="FF:::/Kernel/KMain.CC,#exe {"$. +* There is a feature of the precompiler that allows code to be executed in the middle of compilation and data inserted into the compilation stream. Click here for an example: $LK,"#exe {",A="FF:::/Kernel/KMain.ZC,#exe {"$. * If you output to the cmd line and wish to allow users to scroll around and view data, you can use $LK,"View",A="MN:View"$(). @@ -93,7 +93,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * You can reactivate $FG,2$AutoComplete$FG$ after closing it by pressing $FG,2$$FG$ or $FG,2$$FG$. -* $FG,2$$FG$ to toggle to/from plain text just the $LK,"CDoc",A="MN:CDoc"$ cmd under the cursor. See $LK,"::/Demo/DolDoc/TextDemo.CC"$. +* $FG,2$$FG$ to toggle to/from plain text just the $LK,"CDoc",A="MN:CDoc"$ cmd under the cursor. See $LK,"::/Demo/DolDoc/TextDemo.ZC"$. * If you toggle to plain text when you are working with graphics in a document, you can add duplicate entries for sprites by entering a $FG,2$$$SP...$$$FG$ cmd with the same num. @@ -107,7 +107,7 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * $LK,"GrFloodFill",A="MN:GrFloodFill"$() is slow. $LK,"GrRect",A="MN:GrRect"$() is fast. -* You can customize the $FG,2$wallpaper$FG$. See $LK,"::/Demo/Graphics/WallPaperFish.CC"$. +* You can customize the $FG,2$wallpaper$FG$. See $LK,"::/Demo/Graphics/WallPaperFish.ZC"$. * Your RAM disks will not be reformatted when you reboot if the memory location has not changed and it finds the disk intact. @@ -115,9 +115,9 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * Using a sub-int array, $FG,2$i.u8[3]$FG$, for example, will force a local variable to non-reg. -* You can delete the $FG,4$~/Registry.CC$FG$ file. The policy is that deleting it will restore defaults. It is a text doc, if you want to edit it. See $LK,"RegDefault",A="MN:RegDefault"$, $LK,"RegAppend",A="MN:RegAppend"$, $LK,"RegExe",A="MN:RegExe"$. Be careful of tree indentations. +* You can delete the $FG,4$~/Registry.ZC$FG$ file. The policy is that deleting it will restore defaults. It is a text doc, if you want to edit it. See $LK,"RegDefault",A="MN:RegDefault"$, $LK,"RegAppend",A="MN:RegAppend"$, $LK,"RegExe",A="MN:RegExe"$. Be careful of tree indentations. -* Study $LK,"::/System/Utils/MemRep.CC"$ and $LK,"WallPaper",A="MN:WallPaper"$() to learn how the system resources are put together. +* Study $LK,"::/System/Utils/MemRep.ZC"$ and $LK,"WallPaper",A="MN:WallPaper"$() to learn how the system resources are put together. * The editor's sel-text mechanism allows for disjoint portions of sel text. This is a feature, not a bug -- you can cut-and-paste disjoint text. @@ -139,6 +139,6 @@ $FG,2$Merge("C:/","D:/","+r+d");$FG$ to check your changes. * With $FG,2$start$FG$/$FG,2$end$FG$, common trailing code is fast. Common leading code is slow.$FG$ -* The first line of the $MA-X+PU,"Psalmody",LM="#include \"::/Apps/Psalmody/Run\"\n"$ $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ song files is a comment with a category recognized by $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$(). The categories are $FG,2$"no nothing"$FG$, $FG,2$"has words"$FG$, $FG,2$"has graphics"$FG$, or $FG,2$"special"$FG$. The third character in the song comment is a digit rating number, shown in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$(). You can set the song rating in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.CC,JukeBox"$() by pressing $FG,2$0$FG$-$FG,2$9$FG$. You can press $FG,2$$FG$ to delete songs. +* The first line of the $MA-X+PU,"Psalmody",LM="#include \"::/Apps/Psalmody/Run\"\n"$ $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ song files is a comment with a category recognized by $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$(). The categories are $FG,2$"no nothing"$FG$, $FG,2$"has words"$FG$, $FG,2$"has graphics"$FG$, or $FG,2$"special"$FG$. The third character in the song comment is a digit rating number, shown in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$(). You can set the song rating in $LK,"JukeBox",A="FF:::/Apps/Psalmody/JukeBox.ZC,JukeBox"$() by pressing $FG,2$0$FG$-$FG,2$9$FG$. You can press $FG,2$$FG$ to delete songs. * $FG,8$"Linux" is a trademark owned by Linus Torvalds.$FG$ \ No newline at end of file diff --git a/src/Doc/Transform.DD b/src/Doc/Transform.DD index 73d5d8b8..89d905be 100755 --- a/src/Doc/Transform.DD +++ b/src/Doc/Transform.DD @@ -1,13 +1,13 @@ $WW,1$$LK,"CDC",A="MN:CDC"$'s have a 4x4 matrix for rotating, scaling, skewing and shifting in 3 dimensions. To make the graphics routines use the transform, you must set the $LK,"DCF_TRANSFORMATION",A="MN:DCF_TRANSFORMATION"$ flag. -The matrix consists of ints that have been scaled 32 bits ($LK,"GR_SCALE",A="MN:GR_SCALE"$). See $LK,"::/Demo/Lectures/FixedPoint.CC"$ to learn why. +The matrix consists of ints that have been scaled 32 bits ($LK,"GR_SCALE",A="MN:GR_SCALE"$). See $LK,"::/Demo/Lectures/FixedPoint.ZC"$ to learn why. -See $LK,"Mat4x4IdentEqu",A="MN:Mat4x4IdentEqu"$(), $LK,"Mat4x4IdentNew",A="MN:Mat4x4IdentNew"$(), $LK,"Mat4x4Equ",A="MN:Mat4x4Equ"$() and $LK,"Mat4x4New",A="MN:Mat4x4New"$(). See $LK,"Mat4x4RotX",A="MN:Mat4x4RotX"$(), $LK,"Mat4x4RotY",A="MN:Mat4x4RotY"$(), $LK,"Mat4x4RotZ",A="MN:Mat4x4RotZ"$() and $LK,"Mat4x4Scale",A="MN:Mat4x4Scale"$() to rotate about axes and scale. Combine them with $LK,"Mat4x4MulMat4x4Equ",A="MN:Mat4x4MulMat4x4Equ"$()/$LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$() and assign them to the $LK,"CDC",A="MN:CDC"$.$FG,2$dc$FG$ with $LK,"DCMat4x4Set",A="MN:DCMat4x4Set"$(). See $LK,"::/Demo/Graphics/Box.CC"$. +See $LK,"Mat4x4IdentEqu",A="MN:Mat4x4IdentEqu"$(), $LK,"Mat4x4IdentNew",A="MN:Mat4x4IdentNew"$(), $LK,"Mat4x4Equ",A="MN:Mat4x4Equ"$() and $LK,"Mat4x4New",A="MN:Mat4x4New"$(). See $LK,"Mat4x4RotX",A="MN:Mat4x4RotX"$(), $LK,"Mat4x4RotY",A="MN:Mat4x4RotY"$(), $LK,"Mat4x4RotZ",A="MN:Mat4x4RotZ"$() and $LK,"Mat4x4Scale",A="MN:Mat4x4Scale"$() to rotate about axes and scale. Combine them with $LK,"Mat4x4MulMat4x4Equ",A="MN:Mat4x4MulMat4x4Equ"$()/$LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$() and assign them to the $LK,"CDC",A="MN:CDC"$.$FG,2$dc$FG$ with $LK,"DCMat4x4Set",A="MN:DCMat4x4Set"$(). See $LK,"::/Demo/Graphics/Box.ZC"$. You can rotate single points using $LK,"Mat4x4MulXYZ",A="MN:Mat4x4MulXYZ"$(). -The 4th dimension allows a neat trick where you can place pos shifts (translations), into the matrix and $LK,"Mat4x4MulMat4x4Equ",A="MN:Mat4x4MulMat4x4Equ"$/$LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$ them to combine rotation/shift operations. Normally, you can't combine pos shift operations. See $LK,"Mat4x4TranslationEqu",A="MN:Mat4x4TranslationEqu"$() and $LK,"::/Demo/Graphics/Transform.CC"$. +The 4th dimension allows a neat trick where you can place pos shifts (translations), into the matrix and $LK,"Mat4x4MulMat4x4Equ",A="MN:Mat4x4MulMat4x4Equ"$/$LK,"Mat4x4MulMat4x4New",A="MN:Mat4x4MulMat4x4New"$ them to combine rotation/shift operations. Normally, you can't combine pos shift operations. See $LK,"Mat4x4TranslationEqu",A="MN:Mat4x4TranslationEqu"$() and $LK,"::/Demo/Graphics/Transform.ZC"$. Finally, $LK,"CDC",A="MN:CDC"$'s have an $FG,2$x$FG$, $FG,2$y$FG$ and $FG,2$z$FG$ which is an additional shift (translation). -The transformation is implemented as a callback on the $LK,"CDC",A="MN:CDC"$'s $FG,2$transform()$FG$ member. The default $FG,2$transform()$FG$ callback is $LK,"DCTransform",A="MN:DCTransform"$(). See $LK,"::/Demo/Games/Talons.CC"$ or $LK,"::/Demo/Games/CastleFrankenstein.CC"$ to see how to change the $FG,2$transform()$FG$ callback for foreshortening. +The transformation is implemented as a callback on the $LK,"CDC",A="MN:CDC"$'s $FG,2$transform()$FG$ member. The default $FG,2$transform()$FG$ callback is $LK,"DCTransform",A="MN:DCTransform"$(). See $LK,"::/Demo/Games/Talons.ZC"$ or $LK,"::/Demo/Games/CastleFrankenstein.ZC"$ to see how to change the $FG,2$transform()$FG$ callback for foreshortening. diff --git a/src/Doc/Welcome.DD b/src/Doc/Welcome.DD index a2f29a12..8cf6b891 100755 --- a/src/Doc/Welcome.DD +++ b/src/Doc/Welcome.DD @@ -13,45 +13,45 @@ It's a kayak, not a Titanic -- it will crash if you do something wrong. You qui Conventional thinking is "failure is not an option" for general purpose operating systems. Since this OS is used in addition to Windows or Linux, however, failure is an option -- just use Windows or Linux if you can't do something. We cherry-pick what it will and won't do, to make it maximally beautiful. The following applications more or less form a basis that spans the range of use that ZealOS is intended for: -$LK,"/Demo/Games/BattleLines.CC",A="FI:::/Demo/Games/BattleLines.CC"$ -$LK,"/Demo/Games/BigGuns.CC",A="FI:::/Demo/Games/BigGuns.CC"$ -$LK,"/Demo/Games/BlackDiamond.CC",A="FI:::/Demo/Games/BlackDiamond.CC"$ -$LK,"/Demo/Games/BomberGolf.CC",A="FI:::/Demo/Games/BomberGolf.CC"$ -$LK,"/Demo/Games/CastleFrankenstein.CC",A="FI:::/Demo/Games/CastleFrankenstein.CC"$ -$LK,"/Demo/Games/CharDemo.CC",A="FI:::/Demo/Games/CharDemo.CC"$ -$LK,"/Demo/Games/CircleTrace.CC",A="FI:::/Demo/Games/CircleTrace.CC"$ -$LK,"/Demo/Games/Collision.CC",A="FI:::/Demo/Games/Collision.CC"$ -$LK,"/Demo/Games/Digits.CC",A="FI:::/Demo/Games/Digits.CC"$ -$LK,"/Demo/Games/DunGen.CC",A="FI:::/Demo/Games/DunGen.CC"$ -$LK,"/Demo/Games/Talons.CC",A="FI:::/Demo/Games/Talons.CC"$ -$LK,"/Demo/Games/ElephantWalk.CC",A="FI:::/Demo/Games/ElephantWalk.CC"$ -$LK,"/Demo/Games/FlapBat.CC",A="FI:::/Demo/Games/FlapBat.CC"$ -$LK,"/Demo/Games/FlatTops.CC",A="FI:::/Demo/Games/FlatTops.CC"$ -$LK,"/Demo/Games/Halogen.CC",A="FI:::/Demo/Games/Halogen.CC"$ -$LK,"/Demo/Games/MassSpring.CC",A="FI:::/Demo/Games/MassSpring.CC"$ -$LK,"/Demo/Games/Maze.CC",A="FI:::/Demo/Games/Maze.CC"$ -$LK,"/Demo/Games/RainDrops.CC",A="FI:::/Demo/Games/RainDrops.CC"$ -$LK,"/Demo/Games/RawHide.CC",A="FI:::/Demo/Games/RawHide.CC"$ -$LK,"/Demo/Games/Rocket.CC",A="FI:::/Demo/Games/Rocket.CC"$ -$LK,"/Demo/Games/RocketScience.CC",A="FI:::/Demo/Games/RocketScience.CC"$ -$LK,"/Demo/Games/Squirt.CC",A="FI:::/Demo/Games/Squirt.CC"$ -$LK,"/Demo/Games/TheDead.CC",A="FI:::/Demo/Games/TheDead.CC"$ -$LK,"/Demo/Games/TicTacToe.CC",A="FI:::/Demo/Games/TicTacToe.CC"$ -$LK,"/Demo/Games/TreeCheckers.CC",A="FI:::/Demo/Games/TreeCheckers.CC"$ -$LK,"/Demo/Games/Varoom.CC",A="FI:::/Demo/Games/Varoom.CC"$ -$LK,"/Demo/Games/Wenceslas.CC",A="FI:::/Demo/Games/Wenceslas.CC"$ -$LK,"/Demo/Games/Whap.CC",A="FI:::/Demo/Games/Whap.CC"$ -$LK,"/Demo/Games/Zing.CC",A="FI:::/Demo/Games/Zing.CC"$ -$LK,"/Demo/Games/ZoneOut.CC",A="FI:::/Demo/Games/ZoneOut.CC"$ -$LK,"/Apps/Psalmody/Examples/childish.CC",A="FI:::/Apps/Psalmody/Examples/childish.CC"$ -$LK,"/Apps/Psalmody/Examples/night.CC",A="FI:::/Apps/Psalmody/Examples/night.CC"$ -$LK,"/Apps/Psalmody/Examples/prosper.CC",A="FI:::/Apps/Psalmody/Examples/prosper.CC"$ +$LK,"/Demo/Games/BattleLines.ZC",A="FI:::/Demo/Games/BattleLines.ZC"$ +$LK,"/Demo/Games/BigGuns.ZC",A="FI:::/Demo/Games/BigGuns.ZC"$ +$LK,"/Demo/Games/BlackDiamond.ZC",A="FI:::/Demo/Games/BlackDiamond.ZC"$ +$LK,"/Demo/Games/BomberGolf.ZC",A="FI:::/Demo/Games/BomberGolf.ZC"$ +$LK,"/Demo/Games/CastleFrankenstein.ZC",A="FI:::/Demo/Games/CastleFrankenstein.ZC"$ +$LK,"/Demo/Games/CharDemo.ZC",A="FI:::/Demo/Games/CharDemo.ZC"$ +$LK,"/Demo/Games/CircleTrace.ZC",A="FI:::/Demo/Games/CircleTrace.ZC"$ +$LK,"/Demo/Games/Collision.ZC",A="FI:::/Demo/Games/Collision.ZC"$ +$LK,"/Demo/Games/Digits.ZC",A="FI:::/Demo/Games/Digits.ZC"$ +$LK,"/Demo/Games/DunGen.ZC",A="FI:::/Demo/Games/DunGen.ZC"$ +$LK,"/Demo/Games/Talons.ZC",A="FI:::/Demo/Games/Talons.ZC"$ +$LK,"/Demo/Games/ElephantWalk.ZC",A="FI:::/Demo/Games/ElephantWalk.ZC"$ +$LK,"/Demo/Games/FlapBat.ZC",A="FI:::/Demo/Games/FlapBat.ZC"$ +$LK,"/Demo/Games/FlatTops.ZC",A="FI:::/Demo/Games/FlatTops.ZC"$ +$LK,"/Demo/Games/Halogen.ZC",A="FI:::/Demo/Games/Halogen.ZC"$ +$LK,"/Demo/Games/MassSpring.ZC",A="FI:::/Demo/Games/MassSpring.ZC"$ +$LK,"/Demo/Games/Maze.ZC",A="FI:::/Demo/Games/Maze.ZC"$ +$LK,"/Demo/Games/RainDrops.ZC",A="FI:::/Demo/Games/RainDrops.ZC"$ +$LK,"/Demo/Games/RawHide.ZC",A="FI:::/Demo/Games/RawHide.ZC"$ +$LK,"/Demo/Games/Rocket.ZC",A="FI:::/Demo/Games/Rocket.ZC"$ +$LK,"/Demo/Games/RocketScience.ZC",A="FI:::/Demo/Games/RocketScience.ZC"$ +$LK,"/Demo/Games/Squirt.ZC",A="FI:::/Demo/Games/Squirt.ZC"$ +$LK,"/Demo/Games/TheDead.ZC",A="FI:::/Demo/Games/TheDead.ZC"$ +$LK,"/Demo/Games/TicTacToe.ZC",A="FI:::/Demo/Games/TicTacToe.ZC"$ +$LK,"/Demo/Games/TreeCheckers.ZC",A="FI:::/Demo/Games/TreeCheckers.ZC"$ +$LK,"/Demo/Games/Varoom.ZC",A="FI:::/Demo/Games/Varoom.ZC"$ +$LK,"/Demo/Games/Wenceslas.ZC",A="FI:::/Demo/Games/Wenceslas.ZC"$ +$LK,"/Demo/Games/Whap.ZC",A="FI:::/Demo/Games/Whap.ZC"$ +$LK,"/Demo/Games/Zing.ZC",A="FI:::/Demo/Games/Zing.ZC"$ +$LK,"/Demo/Games/ZoneOut.ZC",A="FI:::/Demo/Games/ZoneOut.ZC"$ +$LK,"/Apps/Psalmody/Examples/childish.ZC",A="FI:::/Apps/Psalmody/Examples/childish.ZC"$ +$LK,"/Apps/Psalmody/Examples/night.ZC",A="FI:::/Apps/Psalmody/Examples/night.ZC"$ +$LK,"/Apps/Psalmody/Examples/prosper.ZC",A="FI:::/Apps/Psalmody/Examples/prosper.ZC"$ Two things to know about ZealOS are that $UL,1$tasks$UL,0$ have $LK,"MAlloc",A="MN:MAlloc"$/$LK,"Free",A="MN:Free"$ heap memory, not applications, and tasks have compiler symbol tables that persist at a scope like environment variables in other operating systems, and the symbols can include functions. With $FG,2$ZealOS$FG$, the command line feeds right into the $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ compiler, line by line, and it places code into memory it $LK,"MAlloc",A="MN:MAlloc"$()s. The compiler is paused at the command line, waiting for input. Naturally, you $FG,2$#include$FG$ a program to load it into memory and, usually, start it. -During the boot process, many files get $LK,"compiled",A="FI:::/StartOS.CC"$ before you have access to the command line. (Don't worry, booting takes only two seconds.) All the header declarations for the operating system are compiled and are available for use in your programs without needing to $FG,2$#include $FG$them. Everything is truly compiled to native $FG,2$$TX,"x86_64",HTML="http://en.wikipedia.org/wiki/Amd64#AMD64"$$FG$ machine code, nothing is $FG,2$interpreted$FG$ and there is no $FG,2$byte code$FG$. +During the boot process, many files get $LK,"compiled",A="FI:::/StartOS.ZC"$ before you have access to the command line. (Don't worry, booting takes only two seconds.) All the header declarations for the operating system are compiled and are available for use in your programs without needing to $FG,2$#include $FG$them. Everything is truly compiled to native $FG,2$$TX,"x86_64",HTML="http://en.wikipedia.org/wiki/Amd64#AMD64"$$FG$ machine code, nothing is $FG,2$interpreted$FG$ and there is no $FG,2$byte code$FG$. Statements at the global scope -- outside the scope of functions -- execute immediately. There is no $FG,2$main()$FG$ function. Instead, you give meaningful names to what would be $FG,2$main()$FG$ functions and you invoke them by calling them with a statement in the global scope, usually at the bottom of your file. @@ -73,7 +73,7 @@ Once Terry was no longer using standard C/C++ syntax, he decided to change every There are no object files in ZealOS and, normally, you don't make executable files either, but you can. That's known as $LK,"Ahead-of-Time",A="FF:::/Doc/Glossary.DD,AOT Compile Mode"$ compilation. Instead, you $LK,"Just in Time",A="FF:::/Doc/Glossary.DD,JIT Compile Mode"$ compile. -Tasks have no priority and are never removed from the queue. Instead, they often poll whatever they are waiting on and swap-out. (Swapping tasks takes half a microsecond and does not involve disk activity or memory maps.) See $LK,"Scheduler",A="FL:::/Kernel/Sched.CC,1"$. Polling keeps it simple. It might be a problem if you had lots of tasks busy, which rarely happens on a home computer. The order of the tasks in the queue determines front-to-back window order. +Tasks have no priority and are never removed from the queue. Instead, they often poll whatever they are waiting on and swap-out. (Swapping tasks takes half a microsecond and does not involve disk activity or memory maps.) See $LK,"Scheduler",A="FL:::/Kernel/Sched.ZC,1"$. Polling keeps it simple. It might be a problem if you had lots of tasks busy, which rarely happens on a home computer. The order of the tasks in the queue determines front-to-back window order. The $FG,2$FAT32$FG$ filesystem is supported to makes exchanging files with a dual booted other operating system easy and there is the simple, 64-bit ZealOS $LK,"RedSea",A="FI:::/Doc/RedSea.DD"$ filesystem. The $LK,"RedSea",A="FI:::/Doc/RedSea.DD"$ has allocation bitmap for clusters and all files are stored contiguously. You can't grow files. @@ -85,9 +85,9 @@ ZealOS is for hobbyist programmers on single user (at a time) home computers, no There is no distinction between the terms $FG,2$task$FG$, $FG,2$process$FG$ or $FG,2$thread$FG$. All have a task record, $LK,"CTask",A="MN:CTask"$, pointed to by the $FG,2$FS$FG$ segment register and are accessed with $FG,4$Fs->$FG$ while $FG,4$Gs->$FG$ points to a $LK,"CCPU",A="MN:CCPU"$ for the current CPU core. Each task can have just one window, but a task can have children with windows. (The segment registers are just used as extra registers -- there is nothing segmented about ZealOS' memory.) It is approximately the case that $FG,2$ZealOS$FG$ is multi-threading, single-processing. -In $FG,2$ZealOS$FG$, $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$$FG$ refers to the father of all tasks. It's never supposed to die. Since tasks inherit the symbols of parents, system-wide stuff is associated with $FG,2$System$FG$. Its heap is like kernel memory in other operating systems. Since $FG,2$System$FG$ is immortal, it's safe to alloc objects, not tied to any mortal task, from $FG,2$System$FG$'s heap. It stays in a server mode, taking requests, so you can ask it to $FG,2$#include$FG$ something, placing that code system-wide. A funny story is that originally Terry Davis called it the $FG,2$root$FG$ task and even had a $FG,2$/Root$FG$ directory :-) $FG,2$System$FG$ executes $LK,"::/StartOS.CC"$ at boot time. +In $FG,2$ZealOS$FG$, $LK,"System Task",A="FF:::/Doc/Glossary.DD,System Task"$$FG$ refers to the father of all tasks. It's never supposed to die. Since tasks inherit the symbols of parents, system-wide stuff is associated with $FG,2$System$FG$. Its heap is like kernel memory in other operating systems. Since $FG,2$System$FG$ is immortal, it's safe to alloc objects, not tied to any mortal task, from $FG,2$System$FG$'s heap. It stays in a server mode, taking requests, so you can ask it to $FG,2$#include$FG$ something, placing that code system-wide. A funny story is that originally Terry Davis called it the $FG,2$root$FG$ task and even had a $FG,2$/Root$FG$ directory :-) $FG,2$System$FG$ executes $LK,"::/StartOS.ZC"$ at boot time. -For easy back-ups, place everything you author in your $FG,2$/Home$FG$ directory and subdirectories. Then, use $LK,"CopyTree",A="MN:CopyTree"$(). That should make upgrading easy, too. Customizable start-up scripts go in your $FG,2$/Home$FG$ directory. The default start-up scripts are in the root directory. Copy the start-up files you wish to customize into $FG,2$/Home$FG$ and modify them. See $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. You can make your own distro that includes everything and is a bootable live CD with $LK,"::/Misc/DoDistro.CC"$. +For easy back-ups, place everything you author in your $FG,2$/Home$FG$ directory and subdirectories. Then, use $LK,"CopyTree",A="MN:CopyTree"$(). That should make upgrading easy, too. Customizable start-up scripts go in your $FG,2$/Home$FG$ directory. The default start-up scripts are in the root directory. Copy the start-up files you wish to customize into $FG,2$/Home$FG$ and modify them. See $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. You can make your own distro that includes everything and is a bootable live CD with $LK,"::/Misc/DoDistro.ZC"$. Typically, your usage pattern through the day will be repeatedly left or right clicking on filenames in a cmd line $LK,"Dir",A="MN:Dir"$() listing. You left-click files to edit them and right-click to $FG,2$#include$FG$ them. To begin a project, type $LK,"Ed",A="MN:Ed"$("filename");, supplying a filename. You can also run programs with $FG,2$$FG$ when in the editor. $FG,2$$FG$ to save and exit the file. You'll need to do a new $LK,"Dir",A="MN:Dir"$() cmd, periodically, so make a macro on your PersonalMenu. Access your PersonalMenu by pressing $FG,2$$FG$, cursoring until you are on top of it and pressing $FG,2$$FG$. @@ -102,13 +102,13 @@ $FG,2$$FG$ closes AutoComplete. $FG,2$$FG$ brings back AutoComplete. $FG,2$$FG$ vertically tiles windows. $FG,2$$FG$ horizontally tiles windows. -The $FG,2$ALT$FG$ keys are defined in $LK,"~/HomeKeyPlugIns.CC"$. You can customize them. +The $FG,2$ALT$FG$ keys are defined in $LK,"~/HomeKeyPlugIns.ZC"$. You can customize them. $FG,2$$FG$ new terminal window. $FG,2$$FG$ switches to the next window. $FG,2$$FG$ kills a window. -$LK,"Find",A="MN:Find"$() is your best friend. There's a wrapper function called $LK,"F",A="MN:F"$() in your $FG,2$~/HomeWrappers.CC$FG$ file. Feel free to make wrapper functions for functions you use often and customize the args. By the way, $LK,"Find",A="MN:Find"$() or $LK,"R",A="MN:R"$() can be used to replace strings across multiple files. You can access $LK,"Find",A="MN:Find"$() using $FG,2$$FG$. +$LK,"Find",A="MN:Find"$() is your best friend. There's a wrapper function called $LK,"F",A="MN:F"$() in your $FG,2$~/HomeWrappers.ZC$FG$ file. Feel free to make wrapper functions for functions you use often and customize the args. By the way, $LK,"Find",A="MN:Find"$() or $LK,"R",A="MN:R"$() can be used to replace strings across multiple files. You can access $LK,"Find",A="MN:Find"$() using $FG,2$$FG$. As you browse code, use the $FG,2$AutoComplete$FG$ window to look-up functions, etc. $FG,2$$FG$ (or whatever number) to follow a symbol to it's source. You can browse deeper and deeper. You go back with $FG,2$$FG$. diff --git a/src/Doc/WhyNotMore.DD b/src/Doc/WhyNotMore.DD index 0981a573..454e7fe0 100755 --- a/src/Doc/WhyNotMore.DD +++ b/src/Doc/WhyNotMore.DD @@ -2,11 +2,11 @@ $WW,1$$FG,5$$TX+CX,"Why Not More?"$$FG$ If a feature cannot be made to work correctly and consistently, professional companies usually remove the feature. Because PC hardware is so diverse, getting things to work on all people's computers is really difficult. For one thing, you practically have to own all the different hardware to write drivers for it. If a company wanted to sell a PC operating system, they would offer a warranty and, therefore, could not get away with amateur behavior. ZealOS absolutely requires 64-bit computers, so we leave behind much trouble, but plenty remains. -The PCI bus interface is what modern hardware uses. Before PCI, life was simple and devices used I/O ports. After studying $LK,"PCI Interrupts",A="FI:::/Demo/Lectures/PCIInterrupts.CC"$ and attempting to do a HDAudio driver, Terry Davis came to realize that modern PCI devices require ten times more code and he cannot even come close to making them work on everyone's machine because with PCI devices there are several models to worry about, unlike with the older ISA bus devices which can be done with one driver. +The PCI bus interface is what modern hardware uses. Before PCI, life was simple and devices used I/O ports. After studying $LK,"PCI Interrupts",A="FI:::/Demo/Lectures/PCIInterrupts.ZC"$ and attempting to do a HDAudio driver, Terry Davis came to realize that modern PCI devices require ten times more code and he cannot even come close to making them work on everyone's machine because with PCI devices there are several models to worry about, unlike with the older ISA bus devices which can be done with one driver. -Currently, ZealOS has no PCI drivers beyond AHCI and networking. Most drivers use I/O ports and operate in ISA bus mode. At this point, we only have one driver for each type of device and it is delightfully simple that way. ZealOS has one $LK,"keyboard",A="FI:::/Kernel/SerialDev/Keyboard.CC"$ driver, one $LK,"mouse",A="FI:::/Kernel/SerialDev/Mouse.CC"$ driver, one $LK,"ATA hard drive",A="FI:::/Kernel/BlkDev/DiskAHCI.CC"$ driver, one $LK,"ATAPI CD/DVD",A="FI:::/Kernel/BlkDev/DiskAHCI.CC"$ driver, one $LK,"32-bit color high-res VBE graphics",A="FI:::/System/Gr/GrScreen.CC"$ video driver and one $LK,"PC Speaker",A="MN:Sound"$ driver. We use the $LK,"PIT timer",A="MN:TimerInit"$ and $LK,"PIC Interrupt Controller",A="MN:IntPICInit"$. We use IRQ0 for timer, IRQ1 for keyboard, and IRQ12 for mouse. If IRQ12 is not firing, we are able to poll the mouse. +Currently, ZealOS has no PCI drivers beyond AHCI and networking. Most drivers use I/O ports and operate in ISA bus mode. At this point, we only have one driver for each type of device and it is delightfully simple that way. ZealOS has one $LK,"keyboard",A="FI:::/Kernel/SerialDev/Keyboard.ZC"$ driver, one $LK,"mouse",A="FI:::/Kernel/SerialDev/Mouse.ZC"$ driver, one $LK,"ATA hard drive",A="FI:::/Kernel/BlkDev/DiskAHCI.ZC"$ driver, one $LK,"ATAPI CD/DVD",A="FI:::/Kernel/BlkDev/DiskAHCI.ZC"$ driver, one $LK,"32-bit color high-res VBE graphics",A="FI:::/System/Gr/GrScreen.ZC"$ video driver and one $LK,"PC Speaker",A="MN:Sound"$ driver. We use the $LK,"PIT timer",A="MN:TimerInit"$ and $LK,"PIC Interrupt Controller",A="MN:IntPICInit"$. We use IRQ0 for timer, IRQ1 for keyboard, and IRQ12 for mouse. If IRQ12 is not firing, we are able to poll the mouse. -In the CPU department, ZealOS has state of the art 64-bit $LK,"long mode",A="FI:::/Kernel/KStart64.CC"$ with $LK,"multicore",A="FI:::/Kernel/MultiProc.CC"$ support. We use the $LK,"APIC",A="MN:MPAPICInit"$ and start-up $LK,"multicore",A="MN:Core0StartMP"$ operation. +In the CPU department, ZealOS has state of the art 64-bit $LK,"long mode",A="FI:::/Kernel/KStart64.ZC"$ with $LK,"multicore",A="FI:::/Kernel/MultiProc.ZC"$ support. We use the $LK,"APIC",A="MN:MPAPICInit"$ and start-up $LK,"multicore",A="MN:Core0StartMP"$ operation. Terry Davis made an incredible accomplishment by getting it to work on practically everyone's computer as long as it is 64-bit and they run inside VMware, QEMU or VirtualBox. diff --git a/src/Doc/Widget.DD b/src/Doc/Widget.DD index a524dc4e..0c2209e3 100755 --- a/src/Doc/Widget.DD +++ b/src/Doc/Widget.DD @@ -39,4 +39,4 @@ $FG,5$Escape$FG$ For macro's, send an $FG,2$$FG$ char to exit before runnin $FG,5$Refresh Data$FG$ updates $FG,2$$$DA...$$$FG$ entry continuously. -$FG,5$Html Link$FG$ stores a link which will be embedded if you generate a html version of a document with $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +$FG,5$Html Link$FG$ stores a link which will be embedded if you generate a html version of a document with $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. diff --git a/src/Doc/ZealC.DD b/src/Doc/ZealC.DD index cdedff5c..4da86617 100755 --- a/src/Doc/ZealC.DD +++ b/src/Doc/ZealC.DD @@ -1,6 +1,6 @@ $WW,1$$FG,5$$TX+CX,"ZealC"$$FG$ -ZealC is a fork of HolyC. The only changes to Terry's HolyC compiler are reformatting, label renames, bugfixes, and additions. Little to no functionality is removed, and nothing is fundamentally altered. Code incompatibilities are usually due to Kernel, System, or user methods changing in name and/or functionality, rather than any differences in the Compiler. See the $LK,"Conversion Script",A="FI:::/System/Utils/ConversionScript.CC"$ for help porting HolyC code to ZealC. +ZealC is a fork of HolyC. The only changes to Terry's HolyC compiler are reformatting, label renames, bugfixes, and additions. Little to no functionality is removed, and nothing is fundamentally altered. Code incompatibilities are usually due to Kernel, System, or user methods changing in name and/or functionality, rather than any differences in the Compiler. See the $LK,"Conversion Script",A="FI:::/System/Utils/ConversionScript.ZC"$ for help porting HolyC code to ZealC. * See $LK,"::/Doc/CompilerOverview.DD"$. @@ -118,7 +118,7 @@ $FG$$ID,-2$ * Allows ranges like "$FG,2$case 4...7:$FG$" in $FG,2$switch$FG$ statements. -* A no case number causes next higher int case in $FG,2$switch$FG$ statements. See $LK,"::/Demo/NullCase.CC"$. +* A no case number causes next higher int case in $FG,2$switch$FG$ statements. See $LK,"::/Demo/NullCase.ZC"$. $ID,2$$FG,2$I64 i; @@ -133,7 +133,7 @@ for (i = 0; i < 20; i++) case: "Eleven\n"; break; //One plus prev case. }$FG$$ID,-2$ -* Switch statements can be nestled with a single switch expression! This is known as a "sub_switch" statement. $FG,2$start$FG$/$FG,2$end$FG$ are used to group cases. Don't goto out of, throw an exception out of, or return out of the $FG,2$start$FG$ front porch area. See $LK,"::/Demo/SubSwitch.CC"$. +* Switch statements can be nestled with a single switch expression! This is known as a "sub_switch" statement. $FG,2$start$FG$/$FG,2$end$FG$ are used to group cases. Don't goto out of, throw an exception out of, or return out of the $FG,2$start$FG$ front porch area. See $LK,"::/Demo/SubSwitch.ZC"$. $ID,2$$FG,2$I64 i; @@ -201,7 +201,7 @@ $FG$$ID,-2$ * There is no question-colon operator. -* ZealOS $LK,"operator precedence",A="FF:::/Compiler/CInit.CC,cmp.binary_ops"$ +* ZealOS $LK,"operator precedence",A="FF:::/Compiler/CInit.ZC,cmp.binary_ops"$ $FG,2$`$FG$, $FG,2$>>$FG$, $FG,2$<<$FG$ $FG,2$*$FG$, $FG,2$/$FG$, $FG,2$%$FG$ $FG,2$&$FG$ @@ -219,7 +219,7 @@ $FG$$ID,-2$ * You can use $LK,"Option",A="MN:Option"$($LK,"OPTf_WARN_DUP_TYPES",A="MN:OPTf_WARN_DUP_TYPES"$, ON) to find duplicate local variable type statements. -* With the $FG,2$#exe{}$FG$ feature in your src code, you can place programs that insert text into the stream of code being compiled. See $LK,"#exe {}",A="FF:::/Kernel/KMain.CC,#exe {"$ for an example where the date/time and compile-time prompting for configuration data is placed into a program. $LK,"StreamPrint",A="MN:StreamPrint"$() places text into a src program stream following the conclusion of the $FG,2$#exe{}$FG$ block. +* With the $FG,2$#exe{}$FG$ feature in your src code, you can place programs that insert text into the stream of code being compiled. See $LK,"#exe {}",A="FF:::/Kernel/KMain.ZC,#exe {"$ for an example where the date/time and compile-time prompting for configuration data is placed into a program. $LK,"StreamPrint",A="MN:StreamPrint"$() places text into a src program stream following the conclusion of the $FG,2$#exe{}$FG$ block. * No $FG,2$#define$FG$ functions exist (Terry was not a fan) @@ -231,25 +231,25 @@ $FG$$ID,-2$ * "$FG,2$$$$FG$" is an escape character. Two dollar signs signify an ordinary $$. See $LK,"DolDoc",A="FI:::/Doc/DolDocOverview.DD"$. In $FG,2$asm$FG$ or $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ code, it also refers to the instruction's address or the offset in a $FG,2$class$FG$ definition. -* $FG,2$union$FG$ is more like a class, so you don't reference it with a $FG,2$union$FG$ label after you define it. Some common unions are declared in $LK,"KernelA.HH",A="MN:U16"$ for 1,2,4 and 8 byte objects. If you place a type in front of a union declaration, that is the type when used by itself. See $LK,"::/Demo/SubIntAccess.CC"$. +* $FG,2$union$FG$ is more like a class, so you don't reference it with a $FG,2$union$FG$ label after you define it. Some common unions are declared in $LK,"KernelA.HH",A="MN:U16"$ for 1,2,4 and 8 byte objects. If you place a type in front of a union declaration, that is the type when used by itself. See $LK,"::/Demo/SubIntAccess.ZC"$. -* $FG,2$class$FG$ member variables can have meta data. $FG,2$format$FG$ and $FG,2$data$FG$ are two meta data types now used. All compiler structures are saved and you can access the compiler's info about classes and variables. See $LK,"::/Demo/ClassMeta.CC"$ and $LK,"DocForm",A="MN:DocForm"$(). +* $FG,2$class$FG$ member variables can have meta data. $FG,2$format$FG$ and $FG,2$data$FG$ are two meta data types now used. All compiler structures are saved and you can access the compiler's info about classes and variables. See $LK,"::/Demo/ClassMeta.ZC"$ and $LK,"DocForm",A="MN:DocForm"$(). -* There is a keyword $FG,2$lastclass$FG$ you use as a default arg. It is set to the class name of the prev arg. See $LK,"::/Demo/LastClass.CC"$, $LK,"ClassRep",A="MN:ClassRep"$(), $LK,"DocForm",A="MN:DocForm"$() and $LK,"::/Demo/Disk/BlkDevRep.CC"$. +* There is a keyword $FG,2$lastclass$FG$ you use as a default arg. It is set to the class name of the prev arg. See $LK,"::/Demo/LastClass.ZC"$, $LK,"ClassRep",A="MN:ClassRep"$(), $LK,"DocForm",A="MN:DocForm"$() and $LK,"::/Demo/Disk/BlkDevRep.ZC"$. -* See $LK,"::/Demo/Exceptions.CC"$. $FG,2$try{} catch{}$FG$ and $FG,2$throw$FG$ are different from C++. $FG,2$throw$FG$ is a function with an 8-byte or less char arg. The char string passed in $FG,2$throw()$FG$ can be accessed from within a $FG,2$catch{}$FG$ using the $FG,2$Fs->except_ch$FG$. Within a $FG,2$catch {}$FG$ block, set the variable $FG,2$Fs->catch_except$FG$ to $FG,2$TRUE$FG$ if you want to terminate the search for a handler. Use $LK,"PutExcept",A="MN:PutExcept"$() as a handler, if you like. +* See $LK,"::/Demo/Exceptions.ZC"$. $FG,2$try{} catch{}$FG$ and $FG,2$throw$FG$ are different from C++. $FG,2$throw$FG$ is a function with an 8-byte or less char arg. The char string passed in $FG,2$throw()$FG$ can be accessed from within a $FG,2$catch{}$FG$ using the $FG,2$Fs->except_ch$FG$. Within a $FG,2$catch {}$FG$ block, set the variable $FG,2$Fs->catch_except$FG$ to $FG,2$TRUE$FG$ if you want to terminate the search for a handler. Use $LK,"PutExcept",A="MN:PutExcept"$() as a handler, if you like. * A function is available similar to $FG,2$sizeof$FG$ which provides the offset of a member of a class. It's called $FG,2$offset$FG$. You place the class name and member inside as in $FG,2$offset(classname.membername)$FG$. It has nothing to do with 16-bit code. Both $FG,2$sizeof$FG$ and $FG,2$offset$FG$ only accept one level of member variables. That is, you can't do $FG,2$sizeof(classname.membername.submembername)$FG$.$FG$ * There is no $FG,2$continue$FG$ statement. Use $FG,2$goto$FG$. -* $FG,2$lock{}$FG$ can be used to apply asm $FG,2$LOCK$FG$ prefixes to code for safe multicore read-modify-write accesses. The code bracked with have $FG,2$LOCK$FG$ asm prefix's applied to relevant insts within. It's a little shoddy. See $LK,"::/Demo/MultiCore/Lock.CC"$. +* $FG,2$lock{}$FG$ can be used to apply asm $FG,2$LOCK$FG$ prefixes to code for safe multicore read-modify-write accesses. The code bracked with have $FG,2$LOCK$FG$ asm prefix's applied to relevant insts within. It's a little shoddy. See $LK,"::/Demo/MultiCore/Lock.ZC"$. * There is a function called $LK,"MSize",A="MN:MSize"$() which gives the size of an object alloced off the heap. For larger size allocations, the system rounds-up to a power of two, so $FG,2$MSize()$FG$ lets you know the real size and you can take full advantage of it. * You CAN $LK,"Free",A="MN:Free"$() a $FG,2$NULL$FG$ pointer. Useful variants of $LK,"MAlloc",A="MN:MAlloc"$() can be found $LK,"Here",A="MN:CAlloc"$. Each task has a heap and you can $FG,2$MAlloc$FG$ and $FG,2$Free$FG$ off-of other task's heaps, or make an independent heap with $LK,"HeapCtrlInit",A="MN:HeapCtrlInit"$(). See $LK,"HeapLog",A="MN:HeapLog"$() for an example. -* The stack does not grow because virtual mem is not used. It's recommended to allocate large local variables from the heap. You can change $LK,"MEM_DEFAULT_STACK",A="MN:MEM_DEFAULT_STACK"$ and recompile $FG,2$Kernel$FG$ or request more when doing a $LK,"Spawn",A="MN:Spawn"$(). You can use $LK,"CallStackGrow",A="MN:CallStackGrow"$(), but it's odd. See $LK,"::/Demo/StackGrow.CC"$. +* The stack does not grow because virtual mem is not used. It's recommended to allocate large local variables from the heap. You can change $LK,"MEM_DEFAULT_STACK",A="MN:MEM_DEFAULT_STACK"$ and recompile $FG,2$Kernel$FG$ or request more when doing a $LK,"Spawn",A="MN:Spawn"$(). You can use $LK,"CallStackGrow",A="MN:CallStackGrow"$(), but it's odd. See $LK,"::/Demo/StackGrow.ZC"$. * Only one base class is allowed. diff --git a/src/Home/DoDistro.CC b/src/Home/DoDistro.ZC similarity index 90% rename from src/Home/DoDistro.CC rename to src/Home/DoDistro.ZC index 3a3655d9..b8b4738c 100755 --- a/src/Home/DoDistro.CC +++ b/src/Home/DoDistro.ZC @@ -15,7 +15,7 @@ U0 MakeMyISO(U8 *_out_iso_filename) return; } - DocTreeFWrite("/System/Define.CC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", line_count); + DocTreeFWrite("/System/Define.ZC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", line_count); DefinePrint("DD_ZEALOS_LOC", "%,d", line_count); "Total LOC:%12,d\n\n", line_count; @@ -24,7 +24,7 @@ U0 MakeMyISO(U8 *_out_iso_filename) Del(out_iso_filename); // Generate all HTML docs before ISO creation. - PopUpRunFile("::/Home/HtmlGen.CC"); + PopUpRunFile("::/Home/HtmlGen.ZC"); ProgressBarsReset; progress1_max = 14; @@ -42,7 +42,7 @@ U0 MakeMyISO(U8 *_out_iso_filename) progress1++; CopyTree("/Home", "/Distro/Home"); progress1++; - Del("/Distro/Home/Registry.CC"); + Del("/Distro/Home/Registry.ZC"); CopyTree("/System", "/Distro/System"); progress1++; CopyTree("/Apps", "/Distro/Apps"); @@ -79,4 +79,4 @@ U0 MakeMyISO(U8 *_out_iso_filename) MakeMyISO("/Tmp/MyDistro.ISO.C"); -// Study the account examples $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$. +// Study the account examples $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.ZC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.ZC,1"$. diff --git a/src/Home/HtmlGen.CC b/src/Home/HtmlGen.ZC similarity index 93% rename from src/Home/HtmlGen.CC rename to src/Home/HtmlGen.ZC index b6fe3f18..0453a0c6 100755 --- a/src/Home/HtmlGen.CC +++ b/src/Home/HtmlGen.ZC @@ -1,17 +1,17 @@ /* This converts the entire OS into HTML. -See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +See $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. Notice that an entry like $$TX,"GOOGLE",HTML="http://www.google.com"$$ will be converted to text in the html with an html link. -Terry cheated by hardcoding $LK,"www.templeos.org",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.CC,www.templeos.org"$ as the website +Terry cheated by hardcoding $LK,"www.templeos.org",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.ZC,www.templeos.org"$ as the website for $LK,"ZealOS Links",A="MN:LK_FILE"$. Why don't you copy -$LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$ to your /Home directory +$LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$ to your /Home directory and modify it? You are welcome to link to http://www.templeos.org if you want file that come on the ZealOS distribution. -You can pass html meta data as args to $LK,"ToHtml",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.CC,ToHtml"$(). +You can pass html meta data as args to $LK,"ToHtml",A="FF:::/Demo/ToHtmlToTXTDemo/ToHtml.ZC,ToHtml"$(). */ Cd(__DIR__);; diff --git a/src/Home/K.CC b/src/Home/K.ZC similarity index 90% rename from src/Home/K.CC rename to src/Home/K.ZC index 8efef7f3..545a4185 100755 --- a/src/Home/K.CC +++ b/src/Home/K.ZC @@ -30,8 +30,8 @@ if (YorN) "PopUp(\"#include \\\"DoDistro\\\";;" "if (DriveIsWritable)" "{" - "Del(\\\"~/Registry.CC\\\");" - "Del(\\\"~/MakeHome.CC\\\");" + "Del(\\\"~/Registry.ZC\\\");" + "Del(\\\"~/MakeHome.ZC\\\");" "OutU16(0x4004, 0x3400);" "}\");"); diff --git a/src/Home/Net/Drivers/E1000.CC b/src/Home/Net/Drivers/E1000.ZC similarity index 100% rename from src/Home/Net/Drivers/E1000.CC rename to src/Home/Net/Drivers/E1000.ZC diff --git a/src/Home/Net/Drivers/PCNet.CC b/src/Home/Net/Drivers/PCNet.ZC similarity index 99% rename from src/Home/Net/Drivers/PCNet.CC rename to src/Home/Net/Drivers/PCNet.ZC index 5f25ed4b..65826a15 100755 --- a/src/Home/Net/Drivers/PCNet.CC +++ b/src/Home/Net/Drivers/PCNet.ZC @@ -2,7 +2,7 @@ Author: TomAwezome Driver is based on: - - minexew's ShrineOS PCNet.CC implementation + - minexew's ShrineOS PCNet implementation - OSDev AMD_PCNET documentation - AMD PCnet(TM)-PCI datasheet - any other useful sources. diff --git a/src/Home/Net/Drivers/Run.CC b/src/Home/Net/Drivers/Run.ZC similarity index 100% rename from src/Home/Net/Drivers/Run.CC rename to src/Home/Net/Drivers/Run.ZC diff --git a/src/Home/Net/Drivers/VirtIONet.CC b/src/Home/Net/Drivers/VirtIONet.ZC similarity index 100% rename from src/Home/Net/Drivers/VirtIONet.CC rename to src/Home/Net/Drivers/VirtIONet.ZC diff --git a/src/Home/Net/Load.CC b/src/Home/Net/Load.ZC similarity index 100% rename from src/Home/Net/Load.CC rename to src/Home/Net/Load.ZC diff --git a/src/Home/Net/Programs/Gopher.CC b/src/Home/Net/Programs/Gopher.ZC similarity index 98% rename from src/Home/Net/Programs/Gopher.CC rename to src/Home/Net/Programs/Gopher.ZC index bda9fed9..01842f6a 100755 --- a/src/Home/Net/Programs/Gopher.CC +++ b/src/Home/Net/Programs/Gopher.ZC @@ -329,7 +329,7 @@ MemSetI64(gopher_associations, "GopherDlPrompt", 256); gopher_associations['0'] = "GopherTextView"; gopher_associations['1'] = "GopherMenu"; gopher_associations['7'] = "GopherQueryPrompt"; -/* Include this file from your Net/Load.CC, then add more associations */ +/* Include this file from your Net/Load.ZC, then add more associations */ DocMax; diff --git a/src/Home/Net/Programs/TCPChatClient.CC b/src/Home/Net/Programs/TCPChatClient.ZC similarity index 100% rename from src/Home/Net/Programs/TCPChatClient.CC rename to src/Home/Net/Programs/TCPChatClient.ZC diff --git a/src/Home/Net/Programs/TCPChatServer.CC b/src/Home/Net/Programs/TCPChatServer.ZC similarity index 100% rename from src/Home/Net/Programs/TCPChatServer.CC rename to src/Home/Net/Programs/TCPChatServer.ZC diff --git a/src/Home/Net/Programs/UDPChat.CC b/src/Home/Net/Programs/UDPChat.ZC similarity index 100% rename from src/Home/Net/Programs/UDPChat.CC rename to src/Home/Net/Programs/UDPChat.ZC diff --git a/src/Home/Net/Protocols/ARP.CC b/src/Home/Net/Protocols/ARP.ZC similarity index 100% rename from src/Home/Net/Protocols/ARP.CC rename to src/Home/Net/Protocols/ARP.ZC diff --git a/src/Home/Net/Protocols/DHCP.CC b/src/Home/Net/Protocols/DHCP.ZC similarity index 100% rename from src/Home/Net/Protocols/DHCP.CC rename to src/Home/Net/Protocols/DHCP.ZC diff --git a/src/Home/Net/Protocols/DNS.CC b/src/Home/Net/Protocols/DNS.ZC similarity index 100% rename from src/Home/Net/Protocols/DNS.CC rename to src/Home/Net/Protocols/DNS.ZC diff --git a/src/Home/Net/Protocols/Ethernet.CC b/src/Home/Net/Protocols/Ethernet.ZC similarity index 100% rename from src/Home/Net/Protocols/Ethernet.CC rename to src/Home/Net/Protocols/Ethernet.ZC diff --git a/src/Home/Net/Protocols/ICMP.CC b/src/Home/Net/Protocols/ICMP.ZC similarity index 100% rename from src/Home/Net/Protocols/ICMP.CC rename to src/Home/Net/Protocols/ICMP.ZC diff --git a/src/Home/Net/Protocols/IPV4.CC b/src/Home/Net/Protocols/IPV4.ZC similarity index 100% rename from src/Home/Net/Protocols/IPV4.CC rename to src/Home/Net/Protocols/IPV4.ZC diff --git a/src/Home/Net/Protocols/Sockets.CC b/src/Home/Net/Protocols/Sockets.ZC similarity index 100% rename from src/Home/Net/Protocols/Sockets.CC rename to src/Home/Net/Protocols/Sockets.ZC diff --git a/src/Home/Net/Protocols/TCP/MakeTCP.CC b/src/Home/Net/Protocols/TCP/MakeTCP.ZC similarity index 75% rename from src/Home/Net/Protocols/TCP/MakeTCP.CC rename to src/Home/Net/Protocols/TCP/MakeTCP.ZC index 652da877..e2512559 100755 --- a/src/Home/Net/Protocols/TCP/MakeTCP.CC +++ b/src/Home/Net/Protocols/TCP/MakeTCP.ZC @@ -1,4 +1,4 @@ #include "Protocols/TCP/TCP.HH" #include "Protocols/TCP/TCPTree" -#include "Protocols/TCP/TCP.CC" +#include "Protocols/TCP/TCP.ZC" #include "Protocols/TCP/TCPHandler" diff --git a/src/Home/Net/Protocols/TCP/TCP.CC b/src/Home/Net/Protocols/TCP/TCP.ZC similarity index 100% rename from src/Home/Net/Protocols/TCP/TCP.CC rename to src/Home/Net/Protocols/TCP/TCP.ZC diff --git a/src/Home/Net/Protocols/TCP/TCPHandler.CC b/src/Home/Net/Protocols/TCP/TCPHandler.ZC similarity index 100% rename from src/Home/Net/Protocols/TCP/TCPHandler.CC rename to src/Home/Net/Protocols/TCP/TCPHandler.ZC diff --git a/src/Home/Net/Protocols/TCP/TCPTree.CC b/src/Home/Net/Protocols/TCP/TCPTree.ZC similarity index 100% rename from src/Home/Net/Protocols/TCP/TCPTree.CC rename to src/Home/Net/Protocols/TCP/TCPTree.ZC diff --git a/src/Home/Net/Protocols/UDP/MakeUDP.CC b/src/Home/Net/Protocols/UDP/MakeUDP.ZC similarity index 67% rename from src/Home/Net/Protocols/UDP/MakeUDP.CC rename to src/Home/Net/Protocols/UDP/MakeUDP.ZC index 1b530158..94f58fc7 100755 --- a/src/Home/Net/Protocols/UDP/MakeUDP.CC +++ b/src/Home/Net/Protocols/UDP/MakeUDP.ZC @@ -1,3 +1,3 @@ #include "Protocols/UDP/UDP.HH" #include "Protocols/UDP/UDPTree" -#include "Protocols/UDP/UDP.CC" +#include "Protocols/UDP/UDP.ZC" diff --git a/src/Home/Net/Protocols/UDP/UDP.CC b/src/Home/Net/Protocols/UDP/UDP.ZC similarity index 100% rename from src/Home/Net/Protocols/UDP/UDP.CC rename to src/Home/Net/Protocols/UDP/UDP.ZC diff --git a/src/Home/Net/Protocols/UDP/UDPTree.CC b/src/Home/Net/Protocols/UDP/UDPTree.ZC similarity index 100% rename from src/Home/Net/Protocols/UDP/UDPTree.CC rename to src/Home/Net/Protocols/UDP/UDPTree.ZC diff --git a/src/Home/Net/Start.CC b/src/Home/Net/Start.ZC similarity index 100% rename from src/Home/Net/Start.CC rename to src/Home/Net/Start.ZC diff --git a/src/Home/Net/Tests/ARPTest.CC b/src/Home/Net/Tests/ARPTest.ZC similarity index 100% rename from src/Home/Net/Tests/ARPTest.CC rename to src/Home/Net/Tests/ARPTest.ZC diff --git a/src/Home/Net/Tests/DHCPTest0.CC b/src/Home/Net/Tests/DHCPTest0.ZC similarity index 100% rename from src/Home/Net/Tests/DHCPTest0.CC rename to src/Home/Net/Tests/DHCPTest0.ZC diff --git a/src/Home/Net/Tests/DHCPTest1.CC b/src/Home/Net/Tests/DHCPTest1.ZC similarity index 100% rename from src/Home/Net/Tests/DHCPTest1.CC rename to src/Home/Net/Tests/DHCPTest1.ZC diff --git a/src/Home/Net/Tests/DHCPTest2.CC b/src/Home/Net/Tests/DHCPTest2.ZC similarity index 92% rename from src/Home/Net/Tests/DHCPTest2.CC rename to src/Home/Net/Tests/DHCPTest2.ZC index 44342668..ebe95664 100755 --- a/src/Home/Net/Tests/DHCPTest2.CC +++ b/src/Home/Net/Tests/DHCPTest2.ZC @@ -14,7 +14,7 @@ U0 DHCPTest() if (ipv4_globals.local_ip != 0) { "\nThis test will only work on unconfigured network.\n"; - "To force for testing, comment out $FG,0$NetConfigure;$FG$ in $LK,"Run.CC",A="FF:C:/Home/Net/Run.CC,NetConfigure"$.\n\n"; + "To force for testing, comment out $FG,0$NetConfigure;$FG$ in $LK,"Run.ZC",A="FF:C:/Home/Net/Run.ZC,NetConfigure"$.\n\n"; return; } diff --git a/src/Home/Net/Tests/DNSTest.CC b/src/Home/Net/Tests/DNSTest.ZC similarity index 100% rename from src/Home/Net/Tests/DNSTest.CC rename to src/Home/Net/Tests/DNSTest.ZC diff --git a/src/Home/Net/Tests/EthernetTest.CC b/src/Home/Net/Tests/EthernetTest.ZC similarity index 100% rename from src/Home/Net/Tests/EthernetTest.CC rename to src/Home/Net/Tests/EthernetTest.ZC diff --git a/src/Home/Net/Tests/HostTest0.CC b/src/Home/Net/Tests/HostTest0.ZC similarity index 100% rename from src/Home/Net/Tests/HostTest0.CC rename to src/Home/Net/Tests/HostTest0.ZC diff --git a/src/Home/Net/Tests/HostTest1.CC b/src/Home/Net/Tests/HostTest1.ZC similarity index 100% rename from src/Home/Net/Tests/HostTest1.CC rename to src/Home/Net/Tests/HostTest1.ZC diff --git a/src/Home/Net/Tests/ICMPTest.CC b/src/Home/Net/Tests/ICMPTest.ZC similarity index 100% rename from src/Home/Net/Tests/ICMPTest.CC rename to src/Home/Net/Tests/ICMPTest.ZC diff --git a/src/Home/Net/Tests/IPV4Test.CC b/src/Home/Net/Tests/IPV4Test.ZC similarity index 100% rename from src/Home/Net/Tests/IPV4Test.CC rename to src/Home/Net/Tests/IPV4Test.ZC diff --git a/src/Home/Net/Tests/PCNetTest.CC b/src/Home/Net/Tests/PCNetTest.ZC similarity index 100% rename from src/Home/Net/Tests/PCNetTest.CC rename to src/Home/Net/Tests/PCNetTest.ZC diff --git a/src/Home/Net/Tests/PCP.CC b/src/Home/Net/Tests/PCP.ZC similarity index 100% rename from src/Home/Net/Tests/PCP.CC rename to src/Home/Net/Tests/PCP.ZC diff --git a/src/Home/Net/Tests/TCPEchoClient.CC b/src/Home/Net/Tests/TCPEchoClient.ZC similarity index 100% rename from src/Home/Net/Tests/TCPEchoClient.CC rename to src/Home/Net/Tests/TCPEchoClient.ZC diff --git a/src/Home/Net/Tests/TCPEchoServer.CC b/src/Home/Net/Tests/TCPEchoServer.ZC similarity index 100% rename from src/Home/Net/Tests/TCPEchoServer.CC rename to src/Home/Net/Tests/TCPEchoServer.ZC diff --git a/src/Home/Net/Tests/TCPTest0.CC b/src/Home/Net/Tests/TCPTest0.ZC similarity index 100% rename from src/Home/Net/Tests/TCPTest0.CC rename to src/Home/Net/Tests/TCPTest0.ZC diff --git a/src/Home/Net/Tests/TCPTest1.CC b/src/Home/Net/Tests/TCPTest1.ZC similarity index 100% rename from src/Home/Net/Tests/TCPTest1.CC rename to src/Home/Net/Tests/TCPTest1.ZC diff --git a/src/Home/Net/Tests/TCPTest2.CC b/src/Home/Net/Tests/TCPTest2.ZC similarity index 100% rename from src/Home/Net/Tests/TCPTest2.CC rename to src/Home/Net/Tests/TCPTest2.ZC diff --git a/src/Home/Net/Tests/UDPSocketTest0.CC b/src/Home/Net/Tests/UDPSocketTest0.ZC similarity index 100% rename from src/Home/Net/Tests/UDPSocketTest0.CC rename to src/Home/Net/Tests/UDPSocketTest0.ZC diff --git a/src/Home/Net/Tests/UDPSocketTest1.CC b/src/Home/Net/Tests/UDPSocketTest1.ZC similarity index 100% rename from src/Home/Net/Tests/UDPSocketTest1.CC rename to src/Home/Net/Tests/UDPSocketTest1.ZC diff --git a/src/Home/Net/Tests/UDPSocketTest2.CC b/src/Home/Net/Tests/UDPSocketTest2.ZC similarity index 100% rename from src/Home/Net/Tests/UDPSocketTest2.CC rename to src/Home/Net/Tests/UDPSocketTest2.ZC diff --git a/src/Home/Net/Tests/UDPTest0.CC b/src/Home/Net/Tests/UDPTest0.ZC similarity index 100% rename from src/Home/Net/Tests/UDPTest0.CC rename to src/Home/Net/Tests/UDPTest0.ZC diff --git a/src/Home/Net/Tests/UDPTest1.CC b/src/Home/Net/Tests/UDPTest1.ZC similarity index 100% rename from src/Home/Net/Tests/UDPTest1.CC rename to src/Home/Net/Tests/UDPTest1.ZC diff --git a/src/Home/Net/Utilities/BST.CC b/src/Home/Net/Utilities/BST.ZC similarity index 100% rename from src/Home/Net/Utilities/BST.CC rename to src/Home/Net/Utilities/BST.ZC diff --git a/src/Home/Net/Utilities/JSON/JSON.CC b/src/Home/Net/Utilities/JSON/JSON.ZC similarity index 100% rename from src/Home/Net/Utilities/JSON/JSON.CC rename to src/Home/Net/Utilities/JSON/JSON.ZC diff --git a/src/Home/Net/Utilities/Net.HH b/src/Home/Net/Utilities/Net.HH index 61101864..677f37ac 100755 --- a/src/Home/Net/Utilities/Net.HH +++ b/src/Home/Net/Utilities/Net.HH @@ -20,9 +20,9 @@ #define IP_ADDRESS_LENGTH 4 -/* NICs reroute PCI interrupts to software. See $LK,"PCNet",A="FF:C:/Home/Net/Drivers/PCNet.CC,irq = "$. +/* NICs reroute PCI interrupts to software. See $LK,"PCNet",A="FF:C:/Home/Net/Drivers/PCNet.ZC,irq = "$. Net Handler interrupt is generated whenever an entry is - pushed to the NetQueue. See $LK,"NetHandler",A="FF:C:/Home/Net/Utilities/NetHandler.CC,I_NETHANDLER"$. */ + pushed to the NetQueue. See $LK,"NetHandler",A="FF:C:/Home/Net/Utilities/NetHandler.ZC,I_NETHANDLER"$. */ DefinePrint("I_NETHANDLER", "%d", IntEntryAlloc); diff --git a/src/Home/Net/Utilities/NetHandler.CC b/src/Home/Net/Utilities/NetHandler.ZC similarity index 100% rename from src/Home/Net/Utilities/NetHandler.CC rename to src/Home/Net/Utilities/NetHandler.ZC diff --git a/src/Home/Net/Utilities/NetLog.CC b/src/Home/Net/Utilities/NetLog.ZC similarity index 100% rename from src/Home/Net/Utilities/NetLog.CC rename to src/Home/Net/Utilities/NetLog.ZC diff --git a/src/Home/Net/Utilities/NetQueue.CC b/src/Home/Net/Utilities/NetQueue.ZC similarity index 100% rename from src/Home/Net/Utilities/NetQueue.CC rename to src/Home/Net/Utilities/NetQueue.ZC diff --git a/src/Home/PaletteEditor/Load.CC b/src/Home/PaletteEditor/Load.ZC similarity index 100% rename from src/Home/PaletteEditor/Load.CC rename to src/Home/PaletteEditor/Load.ZC diff --git a/src/Home/PaletteEditor/PaletteEdit.CC b/src/Home/PaletteEditor/PaletteEdit.ZC similarity index 99% rename from src/Home/PaletteEditor/PaletteEdit.CC rename to src/Home/PaletteEditor/PaletteEdit.ZC index 718ca511..30e2e785 100755 --- a/src/Home/PaletteEditor/PaletteEdit.CC +++ b/src/Home/PaletteEditor/PaletteEdit.ZC @@ -221,7 +221,7 @@ U0 PESave(Bool prompt, CCtrl *c) tmp1 = StrNew(&doc->filename.name); StrLastRemove(tmp1, "/", tmp1); - StrReplace(tmp1, ".CC", ""); + StrReplace(tmp1, ".ZC", ""); for (i = 0; i < StrLen(tmp1); i++) if ('A' <= tmp1[i] <= 'Z') tmp1[i] = tmp1[i] + 32; diff --git a/src/Home/PaletteEditor/PaletteGod.CC b/src/Home/PaletteEditor/PaletteGod.ZC similarity index 100% rename from src/Home/PaletteEditor/PaletteGod.CC rename to src/Home/PaletteEditor/PaletteGod.ZC diff --git a/src/Home/PaletteEditor/PaletteSelect.CC b/src/Home/PaletteEditor/PaletteSelect.ZC similarity index 90% rename from src/Home/PaletteEditor/PaletteSelect.CC rename to src/Home/PaletteEditor/PaletteSelect.ZC index 50fde30a..5c5d6809 100755 --- a/src/Home/PaletteEditor/PaletteSelect.CC +++ b/src/Home/PaletteEditor/PaletteSelect.ZC @@ -6,7 +6,7 @@ Cd(__DIR__);; public U0 PaletteSet(U8 *palette_name="Slate", Bool persistent=TRUE) {//Pass filename (without ext) as string to load palette U8 *dir = PALETTES_PATH, - *path = MStrPrint("%Q%Q%Q", dir, palette_name, ".CC");//, + *path = MStrPrint("%Q%Q%Q", dir, palette_name, ".ZC");//, // *file = FileRead(path); // I64 temp_file, i; @@ -32,7 +32,7 @@ public I64 PaletteSelect() DocPrint(doc, "$$LTBLUE$$\n\n"); - tmpde1 = FilesFind("~/PaletteEditor/Palettes/*.CC"); + tmpde1 = FilesFind("~/PaletteEditor/Palettes/*.ZC"); if (tmpde1) { diff --git a/src/Home/PaletteEditor/Palettes/Commander.CC b/src/Home/PaletteEditor/Palettes/Commander.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Commander.CC rename to src/Home/PaletteEditor/Palettes/Commander.ZC diff --git a/src/Home/PaletteEditor/Palettes/Green.CC b/src/Home/PaletteEditor/Palettes/Green.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Green.CC rename to src/Home/PaletteEditor/Palettes/Green.ZC diff --git a/src/Home/PaletteEditor/Palettes/Marine.CC b/src/Home/PaletteEditor/Palettes/Marine.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Marine.CC rename to src/Home/PaletteEditor/Palettes/Marine.ZC diff --git a/src/Home/PaletteEditor/Palettes/Slate.CC b/src/Home/PaletteEditor/Palettes/Slate.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Slate.CC rename to src/Home/PaletteEditor/Palettes/Slate.ZC diff --git a/src/Home/PaletteEditor/Palettes/Temple.CC b/src/Home/PaletteEditor/Palettes/Temple.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Temple.CC rename to src/Home/PaletteEditor/Palettes/Temple.ZC diff --git a/src/Home/PaletteEditor/Palettes/Zsnes.CC b/src/Home/PaletteEditor/Palettes/Zsnes.ZC similarity index 100% rename from src/Home/PaletteEditor/Palettes/Zsnes.CC rename to src/Home/PaletteEditor/Palettes/Zsnes.ZC diff --git a/src/Home/PaletteEditor/Run.CC b/src/Home/PaletteEditor/Run.ZC similarity index 100% rename from src/Home/PaletteEditor/Run.CC rename to src/Home/PaletteEditor/Run.ZC diff --git a/src/Home/SSE.CC b/src/Home/SSE.ZC similarity index 100% rename from src/Home/SSE.CC rename to src/Home/SSE.ZC diff --git a/src/HomeKeyPlugIns.CC b/src/HomeKeyPlugIns.ZC similarity index 100% rename from src/HomeKeyPlugIns.CC rename to src/HomeKeyPlugIns.ZC diff --git a/src/HomeLocalize.CC b/src/HomeLocalize.ZC similarity index 100% rename from src/HomeLocalize.CC rename to src/HomeLocalize.ZC diff --git a/src/HomeSys.CC b/src/HomeSys.ZC similarity index 94% rename from src/HomeSys.CC rename to src/HomeSys.ZC index 15133f3a..2820b304 100755 --- a/src/HomeSys.CC +++ b/src/HomeSys.ZC @@ -35,7 +35,7 @@ U0 StartUpTasks() Silent(OFF); //no output to screen if (sys_boot_src.u16[0] != BOOT_SRC_RAM) - PopUp("ExeFile2(\"::/System/ZSplash.CC\");"); + PopUp("ExeFile2(\"::/System/ZSplash.ZC\");"); } StartUpTasks; diff --git a/src/HomeWrappers.CC b/src/HomeWrappers.ZC similarity index 100% rename from src/HomeWrappers.CC rename to src/HomeWrappers.ZC diff --git a/src/Kernel/BlkDev/DiskAHCI.CC b/src/Kernel/BlkDev/DiskAHCI.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskAHCI.CC rename to src/Kernel/BlkDev/DiskAHCI.ZC diff --git a/src/Kernel/BlkDev/DiskATAId.CC b/src/Kernel/BlkDev/DiskATAId.ZC similarity index 97% rename from src/Kernel/BlkDev/DiskATAId.CC rename to src/Kernel/BlkDev/DiskATAId.ZC index 5b329aee..6d505445 100755 --- a/src/Kernel/BlkDev/DiskATAId.CC +++ b/src/Kernel/BlkDev/DiskATAId.ZC @@ -7,7 +7,7 @@ CBlkDev *ATAMount(U8 first_drive_let, I64 type, I64 port_num) res = BlkDevNextFreeSlot(first_drive_let, type); res->port_num = port_num; res->ahci_port = &blkdev.ahci_hba->ports[port_num]; - res->ahci_port->cmd_list_base = NULL; // See $LK+PU,"AHCIAtaInit",A="FF:::/Kernel/BlkDev/DiskAHCI.CC,if (bd->ahci_port->cmd_list_base)"$ ... + res->ahci_port->cmd_list_base = NULL; // See $LK+PU,"AHCIAtaInit",A="FF:::/Kernel/BlkDev/DiskAHCI.ZC,if (bd->ahci_port->cmd_list_base)"$ ... if (BlkDevAdd(res,, FALSE, FALSE)) return res; } diff --git a/src/Kernel/BlkDev/DiskAddDev.CC b/src/Kernel/BlkDev/DiskAddDev.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskAddDev.CC rename to src/Kernel/BlkDev/DiskAddDev.ZC diff --git a/src/Kernel/BlkDev/DiskBlk.CC b/src/Kernel/BlkDev/DiskBlk.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskBlk.CC rename to src/Kernel/BlkDev/DiskBlk.ZC diff --git a/src/Kernel/BlkDev/DiskBlkDev.CC b/src/Kernel/BlkDev/DiskBlkDev.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskBlkDev.CC rename to src/Kernel/BlkDev/DiskBlkDev.ZC diff --git a/src/Kernel/BlkDev/DiskCDDVD.CC b/src/Kernel/BlkDev/DiskCDDVD.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskCDDVD.CC rename to src/Kernel/BlkDev/DiskCDDVD.ZC diff --git a/src/Kernel/BlkDev/DiskCFile.CC b/src/Kernel/BlkDev/DiskCFile.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskCFile.CC rename to src/Kernel/BlkDev/DiskCFile.ZC diff --git a/src/Kernel/BlkDev/DiskCache.CC b/src/Kernel/BlkDev/DiskCache.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskCache.CC rename to src/Kernel/BlkDev/DiskCache.ZC diff --git a/src/Kernel/BlkDev/DiskClus.CC b/src/Kernel/BlkDev/DiskClus.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskClus.CC rename to src/Kernel/BlkDev/DiskClus.ZC diff --git a/src/Kernel/BlkDev/DiskCopy.CC b/src/Kernel/BlkDev/DiskCopy.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskCopy.CC rename to src/Kernel/BlkDev/DiskCopy.ZC diff --git a/src/Kernel/BlkDev/DiskDirA.CC b/src/Kernel/BlkDev/DiskDirA.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskDirA.CC rename to src/Kernel/BlkDev/DiskDirA.ZC diff --git a/src/Kernel/BlkDev/DiskDirB.CC b/src/Kernel/BlkDev/DiskDirB.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskDirB.CC rename to src/Kernel/BlkDev/DiskDirB.ZC diff --git a/src/Kernel/BlkDev/DiskDirContext.CC b/src/Kernel/BlkDev/DiskDirContext.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskDirContext.CC rename to src/Kernel/BlkDev/DiskDirContext.ZC diff --git a/src/Kernel/BlkDev/DiskDrive.CC b/src/Kernel/BlkDev/DiskDrive.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskDrive.CC rename to src/Kernel/BlkDev/DiskDrive.ZC diff --git a/src/Kernel/BlkDev/DiskFile.CC b/src/Kernel/BlkDev/DiskFile.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskFile.CC rename to src/Kernel/BlkDev/DiskFile.ZC diff --git a/src/Kernel/BlkDev/DiskFind.CC b/src/Kernel/BlkDev/DiskFind.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskFind.CC rename to src/Kernel/BlkDev/DiskFind.ZC diff --git a/src/Kernel/BlkDev/DiskFormat.CC b/src/Kernel/BlkDev/DiskFormat.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskFormat.CC rename to src/Kernel/BlkDev/DiskFormat.ZC diff --git a/src/Kernel/BlkDev/DiskStrA.CC b/src/Kernel/BlkDev/DiskStrA.ZC similarity index 98% rename from src/Kernel/BlkDev/DiskStrA.CC rename to src/Kernel/BlkDev/DiskStrA.ZC index 2b1da9a7..1e00af9d 100755 --- a/src/Kernel/BlkDev/DiskStrA.CC +++ b/src/Kernel/BlkDev/DiskStrA.ZC @@ -324,10 +324,10 @@ U8 *DirFile(U8 *dirname, U8 *name=NULL, U8 *_extension=NULL) {/*Strips file from dirname, scans for file upward until found or returns default. -("/Kernel/KHashA.CC",NULL,NULL) returns "D:/Kernel" +("/Kernel/KHashA.ZC",NULL,NULL) returns "D:/Kernel" ("/Kernel",NULL,"PRJ") returns "D:/Kernel/Kernel.PRJ" ("/Kernel/BlkDev",NULL,"PRJ") returns "D:/Kernel/Kernel.PRJ" -("/Apps/Psalmody","Load","CC") returns "D:/Apps/Psalmody/Load.CC" +("/Apps/Psalmody","Load","ZC") returns "D:/Apps/Psalmody/Load.ZC" */ U8 *st = DirNameAbs(dirname), *st2, *st3, *res, *default = NULL, *ext; diff --git a/src/Kernel/BlkDev/DiskStrB.CC b/src/Kernel/BlkDev/DiskStrB.ZC similarity index 100% rename from src/Kernel/BlkDev/DiskStrB.CC rename to src/Kernel/BlkDev/DiskStrB.ZC diff --git a/src/Kernel/BlkDev/FileSysFAT.CC b/src/Kernel/BlkDev/FileSysFAT.ZC similarity index 100% rename from src/Kernel/BlkDev/FileSysFAT.CC rename to src/Kernel/BlkDev/FileSysFAT.ZC diff --git a/src/Kernel/BlkDev/FileSysRedSea.CC b/src/Kernel/BlkDev/FileSysRedSea.ZC similarity index 100% rename from src/Kernel/BlkDev/FileSysRedSea.CC rename to src/Kernel/BlkDev/FileSysRedSea.ZC diff --git a/src/Kernel/BlkDev/MakeBlkDev.CC b/src/Kernel/BlkDev/MakeBlkDev.ZC similarity index 100% rename from src/Kernel/BlkDev/MakeBlkDev.CC rename to src/Kernel/BlkDev/MakeBlkDev.ZC diff --git a/src/Kernel/Display.CC b/src/Kernel/Display.ZC similarity index 100% rename from src/Kernel/Display.CC rename to src/Kernel/Display.ZC diff --git a/src/Kernel/EdLite.CC b/src/Kernel/EdLite.ZC similarity index 99% rename from src/Kernel/EdLite.CC rename to src/Kernel/EdLite.ZC index 52323068..9a98a441 100755 --- a/src/Kernel/EdLite.CC +++ b/src/Kernel/EdLite.ZC @@ -349,7 +349,7 @@ Bool EdLite(U8 *filename, I64 num=1, I64 edf_dof_flags=0) } U0 ToFileLine(U8 *_fl_file_line, U8 **_filename, I64 *_linenum) -{//"FI:D:/Dir/File.CC,123" to "D:/Dir/File.CC" and 123. +{//"FI:D:/Dir/File.ZC,123" to "D:/Dir/File.ZC" and 123. U8 *st, *fl_file_line = StrNew(_fl_file_line); I64 linenum; diff --git a/src/Kernel/FontStd.CC b/src/Kernel/FontStd.ZC similarity index 100% rename from src/Kernel/FontStd.CC rename to src/Kernel/FontStd.ZC diff --git a/src/Kernel/FunSeg.CC b/src/Kernel/FunSeg.ZC similarity index 100% rename from src/Kernel/FunSeg.CC rename to src/Kernel/FunSeg.ZC diff --git a/src/Kernel/Job.CC b/src/Kernel/Job.ZC similarity index 99% rename from src/Kernel/Job.CC rename to src/Kernel/Job.ZC index b9679f44..983a40da 100755 --- a/src/Kernel/Job.CC +++ b/src/Kernel/Job.ZC @@ -240,7 +240,7 @@ Bool JobResScan(CJob *request=NULL, I64 *_res=NULL) } I64 JobResGet(CJob *request=NULL) -{//See $LK,"::/Demo/MultiCore/Lock.CC"$ +{//See $LK,"::/Demo/MultiCore/Lock.ZC"$ I64 res; CJob *tmpc1; @@ -540,7 +540,7 @@ U0 SysErr(U8 *format, ...) } U0 XTalk(CTask *task, U8 *format, ...) -{//Sends text to other task. See $LK,"::/Misc/OSTestSuite.CC"$. +{//Sends text to other task. See $LK,"::/Misc/OSTestSuite.ZC"$. U8 *buf = StrPrintJoin(NULL, format, argc, argv), *st = SysStrNew(buf), *st2 = MStrPrint("\"%%s\",%d;Free(%d);", st, st); TaskText(task, NULL, st2, 0); @@ -578,7 +578,7 @@ U0 InFile(U8 *filename) } U0 In(U8 *format, ...) -{//Send text to own input buffer. See $LK,"::/Demo/AcctExample/TOS/TOSDistro.CC"$. +{//Send text to own input buffer. See $LK,"::/Demo/AcctExample/TOS/TOSDistro.ZC"$. U8 *buf = StrPrintJoin(NULL, format, argc, argv), *st = SysStrNew(buf); InStr("\"%%s\",%d;Free(%d);", st, st); diff --git a/src/Kernel/KConfig.CC b/src/Kernel/KConfig.ZC similarity index 100% rename from src/Kernel/KConfig.CC rename to src/Kernel/KConfig.ZC diff --git a/src/Kernel/KDataTypes.CC b/src/Kernel/KDataTypes.ZC similarity index 100% rename from src/Kernel/KDataTypes.CC rename to src/Kernel/KDataTypes.ZC diff --git a/src/Kernel/KDate.CC b/src/Kernel/KDate.ZC similarity index 100% rename from src/Kernel/KDate.CC rename to src/Kernel/KDate.ZC diff --git a/src/Kernel/KDebug.CC b/src/Kernel/KDebug.ZC similarity index 99% rename from src/Kernel/KDebug.CC rename to src/Kernel/KDebug.ZC index b01b9b2f..7b5734b9 100755 --- a/src/Kernel/KDebug.CC +++ b/src/Kernel/KDebug.ZC @@ -704,7 +704,7 @@ U0 Fault3(I64 fault_num, I64 fault_err_code) } U0 Fault2(I64 fault_num, I64 fault_err_code) -{//Called from $LK,"Fault2",A="FF:::/Kernel/KInterrupts.CC,Fault2"$. +{//Called from $LK,"Fault2",A="FF:::/Kernel/KInterrupts.ZC,Fault2"$. //$BK,1$Be careful not to swap-out and ruin the saved context$BK,0$ Bool was_raw, was_single_user, was_silent, was_in_debug, was_mouse_enabled; I64 i, old_raw_flags = text.raw_flags; diff --git a/src/Kernel/KDefine.CC b/src/Kernel/KDefine.ZC similarity index 100% rename from src/Kernel/KDefine.CC rename to src/Kernel/KDefine.ZC diff --git a/src/Kernel/KExcept.CC b/src/Kernel/KExcept.ZC similarity index 100% rename from src/Kernel/KExcept.CC rename to src/Kernel/KExcept.ZC diff --git a/src/Kernel/KExterns.CC b/src/Kernel/KExterns.ZC similarity index 100% rename from src/Kernel/KExterns.CC rename to src/Kernel/KExterns.ZC diff --git a/src/Kernel/KGlobals.CC b/src/Kernel/KGlobals.ZC similarity index 88% rename from src/Kernel/KGlobals.CC rename to src/Kernel/KGlobals.ZC index 8164dcd9..7da5e5e5 100755 --- a/src/Kernel/KGlobals.CC +++ b/src/Kernel/KGlobals.ZC @@ -1,5 +1,5 @@ //Compiler initializes globals in AOT bin modules to zero. -//$LK,"Globals Set to Zero Here",A="FF:::/Compiler/ParseStatement.CC,Init AOT global to zero"$. +//$LK,"Globals Set to Zero Here",A="FF:::/Compiler/ParseStatement.ZC,Init AOT global to zero"$. CJob sys_macro_head; CTask *sys_macro_task; @@ -13,7 +13,7 @@ CTask *sys_winmgr_task, U8 *rev_bits_table; //Table with U8 bits reversed CDate local_time_offset; F64 *pow10_I64, - sys_os_version = 1.06; + sys_os_version = 1.07; CAutoCompleteDictGlobals acd; CAutoCompleteGlobals ac; @@ -21,7 +21,7 @@ CBlkDevGlobals blkdev; CCountsGlobals counts = {1, 0, 2676302000, 2676302, 2676302000, FALSE}; CDebugGlobals debug; CDevGlobals dev; -CGridGlobals mouse_grid; //See $LK,"::/Demo/Graphics/Grid.CC"$. +CGridGlobals mouse_grid; //See $LK,"::/Demo/Graphics/Grid.ZC"$. CMouseStateGlobals mouse, mouse_last; CKbdStateGlobals kbd; CKeyDevGlobals keydev; diff --git a/src/Kernel/KHashA.CC b/src/Kernel/KHashA.ZC similarity index 100% rename from src/Kernel/KHashA.CC rename to src/Kernel/KHashA.ZC diff --git a/src/Kernel/KHashB.CC b/src/Kernel/KHashB.ZC similarity index 99% rename from src/Kernel/KHashB.CC rename to src/Kernel/KHashB.ZC index 884e7750..a0c3b8d5 100755 --- a/src/Kernel/KHashB.CC +++ b/src/Kernel/KHashB.ZC @@ -241,7 +241,7 @@ I64 HashListAdd(U8 *list, I64 type, CHashTable *table) } I64 HashDefineListAdd(U8 *dname, I64 type, CHashTable *table) -{//Add define list to a hash table. See $LK,"::/System/DolDoc/DocInit.CC",A="FF:::/System/DolDoc/DocInit.CC,HashDefineListAdd"$. +{//Add define list to a hash table. See $LK,"::/System/DolDoc/DocInit.ZC",A="FF:::/System/DolDoc/DocInit.ZC,HashDefineListAdd"$. CHashDefineStr *tmph; if (tmph = HashFind(dname, Fs->hash_table, HTT_DEFINE_STR)) diff --git a/src/Kernel/KInterrupts.CC b/src/Kernel/KInterrupts.ZC similarity index 97% rename from src/Kernel/KInterrupts.CC rename to src/Kernel/KInterrupts.ZC index a1656d48..2108971a 100755 --- a/src/Kernel/KInterrupts.CC +++ b/src/Kernel/KInterrupts.ZC @@ -88,7 +88,7 @@ INT_FAULT:: PUSH U64 CTask.fault_err_code[RSI] PUSH U64 CTask.fault_num[RSI] MOV RSI, CTask.rsi[RSI] - CALL &Fault2 //See $LK,"Fault2",A="FF:::/Kernel/KDebug.CC,Fault2"$ + CALL &Fault2 //See $LK,"Fault2",A="FF:::/Kernel/KDebug.ZC,Fault2"$ JMP I32 RESTORE_FS_TASK INT_FAULT_ERR_CODE_BITMAP:: @@ -109,8 +109,8 @@ U8 *IntEntryGet(I64 irq) U8 *IntEntrySet(I64 irq, U0 (*fp_new_handler)(), I64 type=IDTET_IRQ) {//Set interrupt handler. Returns old handler. See $LK,"IDTET_IRQ",A="MN:IDTET_IRQ"$. -//See $LK,"::/Demo/Lectures/InterruptDemo.CC"$. -//See $LK,"::/Demo/MultiCore/Interrupts.CC"$. +//See $LK,"::/Demo/Lectures/InterruptDemo.ZC"$. +//See $LK,"::/Demo/MultiCore/Interrupts.ZC"$. I64 fp = fp_new_handler; U8 *old_handler; CIDTEntry *entry; diff --git a/src/Kernel/KLoad.CC b/src/Kernel/KLoad.ZC similarity index 98% rename from src/Kernel/KLoad.CC rename to src/Kernel/KLoad.ZC index 4f6bdf74..b54094df 100755 --- a/src/Kernel/KLoad.CC +++ b/src/Kernel/KLoad.ZC @@ -219,7 +219,7 @@ CBinFile *Load(U8 *filename, I64 ld_flags=0, CBinFile *bfh_addr=INVALID_PTR) return NULL; } - //See $LK,"Patch Table Generation",A="FF:::/Compiler/CMain.CC,IET_ABS_ADDR"$ + //See $LK,"Patch Table Generation",A="FF:::/Compiler/CMain.ZC,IET_ABS_ADDR"$ module_align = 1 << bfh->module_align_bits; if (!module_align || bfh->bin_signature != BIN_SIGNATURE_VAL) { @@ -280,7 +280,7 @@ U0 LoadKernel() { HashGenericAdd(KERNEL_MODULE_NAME, HTT_MODULE | HTF_PUBLIC, mem_boot_base - sizeof(CBinFile)); - //Abs patches done here $LK,"CPatchTableAbsAddr",A="FF:::/Kernel/KStart32.CC,CPatchTableAbsAddr"$. + //Abs patches done here $LK,"CPatchTableAbsAddr",A="FF:::/Kernel/KStart32.ZC,CPatchTableAbsAddr"$. LoadPass1(sys_boot_patch_table_base, mem_boot_base, LDF_NO_ABSS | LDF_SILENT); //No main routines diff --git a/src/Kernel/KMain.CC b/src/Kernel/KMain.ZC similarity index 97% rename from src/Kernel/KMain.CC rename to src/Kernel/KMain.ZC index 1064d254..55a4dc51 100755 --- a/src/Kernel/KMain.CC +++ b/src/Kernel/KMain.ZC @@ -141,7 +141,7 @@ U0 Reboot(Bool format_ramdisks=FALSE) } U0 KMain() -{//Continued from $LK,"KStart64.CC",A="FF:::/Kernel/KStart64.CC,I32 &KMain"$ +{//Continued from $LK,"KStart64.ZC",A="FF:::/Kernel/KStart64.ZC,I32 &KMain"$ CBlkDev *bd; OutU8(PCSPKR, InU8(PCSPKR) & ~3); //Sound; @@ -235,7 +235,7 @@ U0 KMain() counts.time_stamp_freq_initial = TimeCal; Cd("/"); try - ExeFile("StartOS"); //Continues $LK,"/StartOS.CC",A="FL:/StartOS.CC,1"$ + ExeFile("StartOS"); //Continues $LK,"/StartOS.ZC",A="FL:/StartOS.ZC,1"$ catch { Raw(ON); diff --git a/src/Kernel/KMathA.CC b/src/Kernel/KMathA.ZC similarity index 100% rename from src/Kernel/KMathA.CC rename to src/Kernel/KMathA.ZC diff --git a/src/Kernel/KMathB.CC b/src/Kernel/KMathB.ZC similarity index 100% rename from src/Kernel/KMathB.CC rename to src/Kernel/KMathB.ZC diff --git a/src/Kernel/KMisc.CC b/src/Kernel/KMisc.ZC similarity index 99% rename from src/Kernel/KMisc.CC rename to src/Kernel/KMisc.ZC index 1f7435f6..f0de38e4 100755 --- a/src/Kernel/KMisc.CC +++ b/src/Kernel/KMisc.ZC @@ -5,7 +5,7 @@ U0 PortNop() } U0 IntCore0TimerHandler(CTask *) -{//Called from $LK,"IntCore0TimerHandler",A="FF:::/Kernel/KInterrupts.CC,IntCore0TimerHandler"$ +{//Called from $LK,"IntCore0TimerHandler",A="FF:::/Kernel/KInterrupts.ZC,IntCore0TimerHandler"$ I64 i; if (mp_count > 1) diff --git a/src/Kernel/KStart16.CC b/src/Kernel/KStart16.ZC similarity index 92% rename from src/Kernel/KStart16.CC rename to src/Kernel/KStart16.ZC index 42d38130..bb00b773 100755 --- a/src/Kernel/KStart16.CC +++ b/src/Kernel/KStart16.ZC @@ -2,7 +2,7 @@ asm {/* See $LK,"::/Doc/Boot.DD"$. ZealOS starts in real, calls some BIOS routines, switches to 32 bit, and 64 bit mode and continues in $LK,"ZealC",A="FI:::/Doc/ZealC.DD"$ at $LK,"KMain",A="MN:KMain"$(). The boot loader jumps here in real-mode (16-bit). -It actually jumps to the $LK,"CBinFile",A="MN:CBinFile"$ header which is placed just before this by $LK,"the compiler",A="FF:::/Compiler/CMain.CC,16 ALIGN"$. +It actually jumps to the $LK,"CBinFile",A="MN:CBinFile"$ header which is placed just before this by $LK,"the compiler",A="FF:::/Compiler/CMain.ZC,16 ALIGN"$. The header begins with a short jmp to the start of this file's code which begins with the following small jump past some data. This file is first in the Kernel image because it is #included first. $LK,"Kernel.PRJ",A="FF:::/Kernel/Kernel.PRJ,KStart16:1"$ @@ -43,7 +43,7 @@ GDT_BOOT_DS: DU64 0x00CF92000000FFFF, 0; //Gets patched. GDT_BOOT_CS: DU64 0x00CF9A000000FFFF, 0; //Gets patched. GDT_CS32: DU64 0x00CF9A000000FFFF, 0; GDT_CS64: DU64 0x00209A0000000000, 0; //The $LK,"Charter",A="FI:::/Doc/Charter.DD"$ says just ring0. -GDT_CS64_RING3: DU64 0x0020FA0000000000, 0; //$LK,"Ring3",A="FI:::/Demo/Lectures/Ring3.CC"$, so you can play with. +GDT_CS64_RING3: DU64 0x0020FA0000000000, 0; //$LK,"Ring3",A="FI:::/Demo/Lectures/Ring3.ZC"$, so you can play with. GDT_DS: DU64 0x00CF92000000FFFF, 0; GDT_DS_RING3: DU64 0x00CFF2000000FFFF, 0; GDT_TR: DU8 MP_PROCESSORS_NUM * 16 DUP(0); @@ -70,12 +70,12 @@ MAX_SCREEN_HEIGHT: DU16 0; //************************************ CORE0_16BIT_INIT:: -//EAX is $LK,"SYS_BOOT_SRC",A="FF:::/Kernel/KStart16.CC,[SYS_BOOT_SRC]"$. (Value passed from boot block, $LK,"BootHD",A="FF:::/System/Boot/BootHD.CC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.CC,BOOT_SRC_DVD"$, & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.CC,BOOT_SRC_RAM"$.) +//EAX is $LK,"SYS_BOOT_SRC",A="FF:::/Kernel/KStart16.ZC,[SYS_BOOT_SRC]"$. (Value passed from boot block, $LK,"BootHD",A="FF:::/System/Boot/BootHD.ZC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.ZC,BOOT_SRC_DVD"$, & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.ZC,BOOT_SRC_RAM"$.) MOV ECX, EAX MOV AX, (BOOT_RAM_LIMIT - BOOT_STACK_SIZE) / 16 MOV SS, AX MOV SP, BOOT_STACK_SIZE - PUSH ECX //Will be $LK,"SYS_BOOT_SRC",A="FF:::/Kernel/KStart16.CC,[SYS_BOOT_SRC]"$. See $LK,"BootHD",A="FF:::/System/Boot/BootHD.CC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.CC,BOOT_SRC_DVD"$ & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.CC,BOOT_SRC_RAM"$. + PUSH ECX //Will be $LK,"SYS_BOOT_SRC",A="FF:::/Kernel/KStart16.ZC,[SYS_BOOT_SRC]"$. See $LK,"BootHD",A="FF:::/System/Boot/BootHD.ZC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.ZC,BOOT_SRC_DVD"$ & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.ZC,BOOT_SRC_RAM"$. PUSH EBX CALL U16 GET_IP GET_IP: POP BX @@ -308,7 +308,7 @@ GET_IP: POP BX OUT 0x92, AL POP U32 [SYS_BOOT_BLK] - POP U32 [SYS_BOOT_SRC] //See $LK,"BootHD",A="FF:::/System/Boot/BootHD.CC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.CC,BOOT_SRC_DVD"$, & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.CC,BOOT_SRC_RAM"$. + POP U32 [SYS_BOOT_SRC] //See $LK,"BootHD",A="FF:::/System/Boot/BootHD.ZC,BOOT_SRC_HARDDRIVE"$, $LK,"BootDVD",A="FF:::/System/Boot/BootDVD.ZC,BOOT_SRC_DVD"$, & $LK,"BootRAM",A="FF:::/System/Boot/BootRAM.ZC,BOOT_SRC_RAM"$. CLD XOR EAX, EAX diff --git a/src/Kernel/KStart32.CC b/src/Kernel/KStart32.ZC similarity index 97% rename from src/Kernel/KStart32.CC rename to src/Kernel/KStart32.ZC index e3f8bf80..61e2240f 100755 --- a/src/Kernel/KStart32.CC +++ b/src/Kernel/KStart32.ZC @@ -118,5 +118,5 @@ CORE0_32BIT_INIT:: //Entry point for $LK,"BootRAM",A="MN:BootRAM"$. PUSH U32 0 //Return from next call will be 64-bit CALL SYS_ENTER_LONG_MODE - //We fall-through to $LK,"KStart64",A="FL:::/Kernel/KStart64.CC,1"$, next. + //We fall-through to $LK,"KStart64",A="FL:::/Kernel/KStart64.ZC,1"$, next. } diff --git a/src/Kernel/KStart64.CC b/src/Kernel/KStart64.ZC similarity index 97% rename from src/Kernel/KStart64.CC rename to src/Kernel/KStart64.ZC index b69212b3..e4317bf0 100755 --- a/src/Kernel/KStart64.CC +++ b/src/Kernel/KStart64.ZC @@ -81,7 +81,7 @@ USE64 RET //************************************ -SYS_RAM_REBOOT:: //This gets copied high. $LK,"SYS_RAM_REBOOT",A="FF:::/System/Boot/BootRAM.CC,SYS_RAM_REBOOT:2"$ +SYS_RAM_REBOOT:: //This gets copied high. $LK,"SYS_RAM_REBOOT",A="FF:::/System/Boot/BootRAM.ZC,SYS_RAM_REBOOT:2"$ PUSH U32 CGDT.ds //stack seg PUSH U32 BOOT_RAM_LIMIT //stack PUSH U32 0 //flags diff --git a/src/Kernel/KTask.CC b/src/Kernel/KTask.ZC similarity index 98% rename from src/Kernel/KTask.CC rename to src/Kernel/KTask.ZC index e54f1751..d245700c 100755 --- a/src/Kernel/KTask.CC +++ b/src/Kernel/KTask.ZC @@ -128,7 +128,7 @@ CTaskStack *TaskStackNew(I64 stack_size, CTask *task) #exe {Option(OPTf_NO_REG_VAR, ON);}; argpop I64 CallStackGrow(I64 stack_size_threshold, I64 stack_size, /*argpop*/I64 (*fp_addr)(...), ...) {//Grow stack in call with any fixed num of args. -//See $LK,"::/Demo/StackGrow.CC"$. +//See $LK,"::/Demo/StackGrow.ZC"$. CTaskStack *tmps, *tmps2, **_stack; I64 res, *rsp, *rsp2, *old_stack; @@ -249,7 +249,7 @@ I64 TaskInit(CTask *task, I64 stack_size) task->win_bottom = text.rows - 2; if (blkdev.home_dir) - {//Beware System $LK,"TaskInit",A="FF:::/Kernel/KStart64.CC,TaskInit"$. Maybe ok until $LK,"DiskChange",A="FF:::/Kernel/KMain.CC,DiskChange"$(). + {//Beware System $LK,"TaskInit",A="FF:::/Kernel/KStart64.ZC,TaskInit"$. Maybe ok until $LK,"DiskChange",A="FF:::/Kernel/KMain.ZC,DiskChange"$(). task->cur_dv = blkdev.let_to_drive[*blkdev.home_dir - 'A']; task->cur_dir = StrNew(blkdev.home_dir + 2, task); } @@ -262,7 +262,7 @@ I64 TaskInit(CTask *task, I64 stack_size) } CTask *Spawn(U0 (*fp_start_addr)(U8 *data), U8 *data=NULL, U8 *task_name=NULL, - I64 target_cpu=-1, // -1 for current CPU. See $LK,"multi-core",A="FI:::/Demo/MultiCore/LoadTest.CC"$. + I64 target_cpu=-1, // -1 for current CPU. See $LK,"multi-core",A="FI:::/Demo/MultiCore/LoadTest.ZC"$. CTask *parent=NULL, // NULL means sys_task I64 stack_size=0, // 0=default I64 flags=1 << JOBf_ADD_TO_QUE) @@ -590,7 +590,7 @@ I64 TaskEnd() U0 TaskKillDying() {//Delay freeing to prevent asking for trouble with quick reincarnations. -//What if the user is doing this: $LK,"DoTreeCheckers",A="FF:::/Misc/OSTestSuite.CC,DoTreeCheckers"$. +//What if the user is doing this: $LK,"DoTreeCheckers",A="FF:::/Misc/OSTestSuite.ZC,DoTreeCheckers"$. CTaskDying *task, *task1; if (Gs->kill_jiffy < counts.jiffies) diff --git a/src/Kernel/KUtils.CC b/src/Kernel/KUtils.ZC similarity index 100% rename from src/Kernel/KUtils.CC rename to src/Kernel/KUtils.ZC diff --git a/src/Kernel/Kernel.PRJ b/src/Kernel/Kernel.PRJ index ca0ee07b..02d00a32 100755 --- a/src/Kernel/Kernel.PRJ +++ b/src/Kernel/Kernel.PRJ @@ -1,5 +1,5 @@ //Compile this by calling $LK,"BootHDIns",A="MN:BootHDIns"$(). -//Don't do it directly. See $LK,"Comp(\"/Kernel/Kernel\")",A="FF:::/System/Boot/BootHDIns.CC,Comp(\"/Kernel/Kernel\""$. +//Don't do it directly. See $LK,"Comp(\"/Kernel/Kernel\")",A="FF:::/System/Boot/BootHDIns.ZC,Comp(\"/Kernel/Kernel\""$. #exe { Cd(__DIR__);; diff --git a/src/Kernel/KernelA.HH b/src/Kernel/KernelA.HH index 67380dad..eca7a3c8 100755 --- a/src/Kernel/KernelA.HH +++ b/src/Kernel/KernelA.HH @@ -60,7 +60,7 @@ extern class CTask; #help_index "Data Types/Simple" //ZealC union structure is treated as a whole if no member is specified, similar to bit fields. -//See $LK,"::/Demo/SubIntAccess.CC"$. +//See $LK,"::/Demo/SubIntAccess.ZC"$. U16i union U16 { @@ -400,7 +400,7 @@ class CGDT boot_cs, cs32, cs64, //The $LK,"Charter",A="FI:::/Doc/Charter.DD"$ says just ring-0. - cs64_ring3, //$LK,"Ring3",A="FI:::/Demo/Lectures/Ring3.CC"$, in case you want to play around. + cs64_ring3, //$LK,"Ring3",A="FI:::/Demo/Lectures/Ring3.ZC"$, in case you want to play around. ds, ds_ring3, tr[MP_PROCESSORS_NUM], @@ -450,13 +450,13 @@ class CMemE820 #define BIN_SIGNATURE_VAL 'ZCCB' //Zeal ZealC Binary class CBinFile -{//$LK,"Bin File Header Generation",A="FF:::/Compiler/CMain.CC,16 ALIGN"$ by compiler. +{//$LK,"Bin File Header Generation",A="FF:::/Compiler/CMain.ZC,16 ALIGN"$ by compiler. U16 jmp; U8 module_align_bits, reserved; U32 bin_signature; I64 org, - patch_table_offset, //$LK,"Patch Table Generation",A="FF:::/Compiler/CMain.CC,IET_ABS_ADDR"$ + patch_table_offset, //$LK,"Patch Table Generation",A="FF:::/Compiler/CMain.ZC,IET_ABS_ADDR"$ file_size; }; @@ -546,7 +546,7 @@ class CVBEModeShort #help_index "Boot" class CKernel -{//Must match $LK,"OSStartUp",A="FF:::/Kernel/KStart16.CC,MEM_BOOT_BASE"$ +{//Must match $LK,"OSStartUp",A="FF:::/Kernel/KStart16.ZC,MEM_BOOT_BASE"$ CBinFile h; U32 jmp, boot_src, @@ -788,7 +788,7 @@ public class CHashTable }; #help_index "Hash/System" -//Hash table types: $LK,"ST_HTT_TYPES",A="FF:::/Kernel/KDefine.CC,ST_HTT_TYPES"$ +//Hash table types: $LK,"ST_HTT_TYPES",A="FF:::/Kernel/KDefine.ZC,ST_HTT_TYPES"$ #define HTt_EXPORT_SYS_SYM 0 #define HTt_IMPORT_SYS_SYM 1 #define HTt_DEFINE_STR 2 @@ -1522,7 +1522,7 @@ public class CDoc //Linked Text File header I64 (*left_click_link)(CDoc *doc, CDocEntry *doc_e); I64 (*right_click_link)(CDoc *doc, CDocEntry *doc_e); - //See $LK,"::/Apps/Psalmody/JukeBox.CC"$ + //See $LK,"::/Apps/Psalmody/JukeBox.ZC"$ U8 *user_put_data; //Passed to user_put_key() and user_put_s() Bool (*user_put_key)(CDoc *doc, U8 *data, I64 ch, I64 sc); Bool (*user_put_s)(CDoc *doc, U8 *data, U8 *st); @@ -1884,7 +1884,7 @@ class CCodeMisc //Slash value #define SV_R_REG 8 #define SV_I_REG 9 -#define SV_STI_LIKE 10 //$LK,"uasm_slash_val",A="FF:::/Compiler/AsmInit.CC,uasm_slash_val"$ only. +#define SV_STI_LIKE 10 //$LK,"uasm_slash_val",A="FF:::/Compiler/AsmInit.ZC,uasm_slash_val"$ only. #define SV_NONE 11 class CInst { @@ -1956,7 +1956,7 @@ I64 class CAbsCountsI64 }; class CAsmUndefHash -{//Only place created is $LK,"Exp Parser",A="FF:::/Compiler/ParseExp.CC,sizeof(CAsmUndefHash)"$ when an undef is found in an ASM expression. +{//Only place created is $LK,"Exp Parser",A="FF:::/Compiler/ParseExp.ZC,sizeof(CAsmUndefHash)"$ when an undef is found in an ASM expression. CAsmUndefHash *next; CHashExport *hash; }; @@ -3010,9 +3010,9 @@ class CAtapiModeWriteList #define ATAR1_CTRL 2 #help_index "File/FileNames" -#define FILEMASK_JIT "*.CC*;*.HH*" -#define FILEMASK_AOT "*.CC*;*.HH*;*.PRJ*" -#define FILEMASK_SRC "*.CC*;*.HH*;*.IN*;*.PRJ*" +#define FILEMASK_JIT "*.ZC*;*.HH*" +#define FILEMASK_AOT "*.ZC*;*.HH*;*.PRJ*" +#define FILEMASK_SRC "*.ZC*;*.HH*;*.IN*;*.PRJ*" #define FILEMASK_DD FILEMASK_SRC ";*.DD*" #define FILEMASK_TXT FILEMASK_DD ";*.TXT*" #define FILEMASK_GR "*.GR*" @@ -3457,7 +3457,7 @@ public class CDirContext #define FF_CONTIGUOUS 16 #define FF_USE_OLD_DATETIME 32 -public class CFile //See $LK,"::/Demo/Disk/DataBase.CC"$. +public class CFile //See $LK,"::/Demo/Disk/DataBase.ZC"$. { I64 flags; CDirEntry de; @@ -3547,7 +3547,7 @@ public class CBlkPool { I64 locked_flags, alloced_u8s, used_u8s; CMemBlk *mem_free_list, - *mem_free_2meg_list, //This is for Sup1CodeScraps/Mem/Mem2Meg.CC. + *mem_free_2meg_list, //This is for Sup1CodeScraps/Mem/Mem2Meg.ZC. *free_pag_hash[MEM_FREE_PAG_HASH_SIZE], *free_pag_hash2[64 - MEM_PAG_BITS]; }; @@ -3876,7 +3876,7 @@ class CJobCtrl }; #help_index "Messages" -//See $LK,"::/Demo/MessageLoop.CC"$ +//See $LK,"::/Demo/MessageLoop.ZC"$ #define MESSAGE_NULL 0 #define MESSAGE_CMD 1 #define MESSAGE_KEY_DOWN 2 //($LK,"ASCII",A="MN:CH_CTRLA"$,$LK,"scan code",A="FI:::/Doc/CharOverview.DD"$) Press @@ -4004,7 +4004,7 @@ public class CTask //The Fs segment register points to current CTask. scroll_x, scroll_y, scroll_z; //These must be in this order - //for $LK,"TASK_CONTEXT_SAVE",A="FF:::/Kernel/Sched.CC,TASK_CONTEXT_SAVE"$ and $LK,"_TASK_CONTEXT_RESTORE",A="FF:::/Kernel/Sched.CC,_TASK_CONTEXT_RESTORE"$ + //for $LK,"TASK_CONTEXT_SAVE",A="FF:::/Kernel/Sched.ZC,TASK_CONTEXT_SAVE"$ and $LK,"_TASK_CONTEXT_RESTORE",A="FF:::/Kernel/Sched.ZC,_TASK_CONTEXT_RESTORE"$ I64 rip, rflags, rsp, rsi, rax, rcx, rdx, rbx, rbp, rdi, r8, r9, r10, r11, r12, r13, r14, r15; CCPU *gs; CFPU *fpu_mmx; @@ -4273,7 +4273,7 @@ public class CTextGlobals #define DCF_SYMMETRY 0x200 //Must be used with DCF_SYMMETRY set also. -//See $LK,"::/Demo/Games/BigGuns.CC"$ +//See $LK,"::/Demo/Games/BigGuns.ZC"$ #define DCF_JUST_MIRROR 0x400 #define DCF_LOCATE_NEAREST 0x800 @@ -4318,7 +4318,7 @@ public class CDC //0x0000 =100% color.c0 //0x8000 =50% color.c0 50% color.c1 //0x10000=100% color.c1 - //See $LK,"::/Demo/Graphics/SunMoon.CC"$ and $LK,"::/Demo/Graphics/Shading.CC"$. + //See $LK,"::/Demo/Graphics/SunMoon.ZC"$ and $LK,"::/Demo/Graphics/Shading.ZC"$. U64 dither_probability_u16; CDC *brush; diff --git a/src/Kernel/KernelB.HH b/src/Kernel/KernelB.HH index 9a1b0283..f207c52d 100755 --- a/src/Kernel/KernelB.HH +++ b/src/Kernel/KernelB.HH @@ -1,7 +1,7 @@ /* Kernel ASM symbols. $LK,"KernelB",A="FF:::/Kernel/Kernel.PRJ,KernelB"$ Kernel.PRJ $LK,"KernelB",A="FF:::/Compiler/Compiler.PRJ,KernelB"$ Compiler.PRJ -$LK,"KernelB",A="FF:::/StartOS.CC,KernelB"$ StartOS.CC +$LK,"KernelB",A="FF:::/StartOS.ZC,KernelB"$ StartOS.ZC */ #help_index "Bit" @@ -200,7 +200,7 @@ public _intern IC_GS CCPU *Gs(); //GS points to current $LK,"CCPU",A="MN:CCPU"$. public _extern SYS_PCI_BUSES U16 sys_pci_buses; //Number of PCI buses. #help_index "Processor" -public _intern IC_CARRY I64 Carry(); //See $LK,"::/Demo/Carry.CC"$ +public _intern IC_CARRY I64 Carry(); //See $LK,"::/Demo/Carry.ZC"$ public _intern IC_RAX_GET I64 RAXGet(); //Get RAX register value. public _intern IC_RBP_GET U8 *RBPGet(); //Get RBP register value. public _intern IC_RFLAGS_GET I64 RFlagsGet(); //Get RFlags register value. diff --git a/src/Kernel/KeyDev.CC b/src/Kernel/KeyDev.ZC similarity index 100% rename from src/Kernel/KeyDev.CC rename to src/Kernel/KeyDev.ZC diff --git a/src/Kernel/Memory/BlkPool.CC b/src/Kernel/Memory/BlkPool.ZC similarity index 96% rename from src/Kernel/Memory/BlkPool.CC rename to src/Kernel/Memory/BlkPool.ZC index a9c06ec4..3df086a4 100755 --- a/src/Kernel/Memory/BlkPool.CC +++ b/src/Kernel/Memory/BlkPool.ZC @@ -43,7 +43,7 @@ U0 BlkPoolsInit() else code_heap_limit = 0x80000000; - i = code_heap_limit - SYS_16MEG_AREA_LIMIT; //See $LK,"RLf_16MEG_SYS_CODE_BP",A="FF:::/Kernel/Memory/PageTables.CC,RLf_16MEG_SYS_CODE_BP"$ + i = code_heap_limit - SYS_16MEG_AREA_LIMIT; //See $LK,"RLf_16MEG_SYS_CODE_BP",A="FF:::/Kernel/Memory/PageTables.ZC,RLf_16MEG_SYS_CODE_BP"$ BlkPoolAdd(sys_code_bp, SYS_16MEG_AREA_LIMIT, i >> MEM_PAG_BITS); mem_heap_limit = i + SYS_16MEG_AREA_LIMIT - 1; diff --git a/src/Kernel/Memory/HeapCtrl.CC b/src/Kernel/Memory/HeapCtrl.ZC similarity index 92% rename from src/Kernel/Memory/HeapCtrl.CC rename to src/Kernel/Memory/HeapCtrl.ZC index 89a8471b..0ca7062d 100755 --- a/src/Kernel/Memory/HeapCtrl.CC +++ b/src/Kernel/Memory/HeapCtrl.ZC @@ -1,6 +1,6 @@ CHeapCtrl *HeapCtrlInit(CHeapCtrl *hc=NULL, CTask *task=NULL, CBlkPool *bp) {//See $LK,"HeapLog",A="MN:HeapLog"$() for an example. -//Duplicated for $LK,"System Task",A="FF:::/Kernel/KStart64.CC,CHeapCtrl.bp"$. +//Duplicated for $LK,"System Task",A="FF:::/Kernel/KStart64.ZC,CHeapCtrl.bp"$. if (!hc) hc = SysCAlloc(sizeof(CHeapCtrl)); hc->hc_signature = HEAP_CTRL_SIGNATURE_VAL; diff --git a/src/Kernel/Memory/MAllocFree.CC b/src/Kernel/Memory/MAllocFree.ZC similarity index 99% rename from src/Kernel/Memory/MAllocFree.CC rename to src/Kernel/Memory/MAllocFree.ZC index 5eb84d73..92912b7d 100755 --- a/src/Kernel/Memory/MAllocFree.CC +++ b/src/Kernel/Memory/MAllocFree.ZC @@ -222,7 +222,7 @@ MALLOC_FINAL_EXIT: //************************************ _FREE:: -//Be aware of $LK,"heap_hash",A="FF:::/Kernel/Memory/MAllocFree.CC,heap_hash"$ in $LK,"MemPagTaskAlloc",A="MN:MemPagTaskAlloc"$(). +//Be aware of $LK,"heap_hash",A="FF:::/Kernel/Memory/MAllocFree.ZC,heap_hash"$ in $LK,"MemPagTaskAlloc",A="MN:MemPagTaskAlloc"$(). PUSH RBP MOV RBP, RSP PUSH RSI diff --git a/src/Kernel/Memory/MakeMemory.CC b/src/Kernel/Memory/MakeMemory.ZC similarity index 100% rename from src/Kernel/Memory/MakeMemory.CC rename to src/Kernel/Memory/MakeMemory.ZC diff --git a/src/Kernel/Memory/MemPag.CC b/src/Kernel/Memory/MemPag.ZC similarity index 100% rename from src/Kernel/Memory/MemPag.CC rename to src/Kernel/Memory/MemPag.ZC diff --git a/src/Kernel/Memory/MemPhysical.CC b/src/Kernel/Memory/MemPhysical.ZC similarity index 100% rename from src/Kernel/Memory/MemPhysical.CC rename to src/Kernel/Memory/MemPhysical.ZC diff --git a/src/Kernel/Memory/PageTables.CC b/src/Kernel/Memory/PageTables.ZC similarity index 100% rename from src/Kernel/Memory/PageTables.CC rename to src/Kernel/Memory/PageTables.ZC diff --git a/src/Kernel/MultiProc.CC b/src/Kernel/MultiProc.ZC similarity index 97% rename from src/Kernel/MultiProc.CC rename to src/Kernel/MultiProc.ZC index d22424ee..9a7c7cf3 100755 --- a/src/Kernel/MultiProc.CC +++ b/src/Kernel/MultiProc.ZC @@ -4,7 +4,7 @@ USE16 //See $LK,"ZealOS MultiCore",A="FI:::/Doc/MultiCore.DD"$. //This code gets copied to $LK,"MP_VECT_ADDR",A="MN:MP_VECT_ADDR"$. -//See $LK,"MemCopy(MP_VECT_ADDR",A="FF:::/Kernel/MultiProc.CC,MemCopy(mp:2"$. +//See $LK,"MemCopy(MP_VECT_ADDR",A="FF:::/Kernel/MultiProc.ZC,MemCopy(mp:2"$. COREAP_16BIT_INIT:: JMP @@05 @@ -16,7 +16,7 @@ AP_GDT_PTR: DU16 sizeof(CGDT) - 1; WBINVD MOV AX, MP_VECT_ADDR / 16 MOV DS, AX - LGDT U32 [CAP16BitInit.ap_gdt_ptr] //See $LK,"mp->ap_gdt_ptr",A="FF:::/Kernel/MultiProc.CC,mp->ap_gdt_ptr:2"$ + LGDT U32 [CAP16BitInit.ap_gdt_ptr] //See $LK,"mp->ap_gdt_ptr",A="FF:::/Kernel/MultiProc.ZC,mp->ap_gdt_ptr:2"$ MOV EAX, SYS_START_CR0 MOV_CR0_EAX @@ -74,7 +74,7 @@ USE64 } U0 TSSBusy(I64 tr, Bool val=OFF) -{//See $LK,"::/Demo/Lectures/Ring3.CC"$. +{//See $LK,"::/Demo/Lectures/Ring3.ZC"$. LBEqual((&sys_gdt)(U8 *) + tr + 4, 9, val); } @@ -132,7 +132,7 @@ CCPU *CPUStructInit(I64 num, CCPU *c, CTask *executive_task) LBts(&c->idle_task->task_flags, TASKf_IDLE); c->tss = TSSNew(num); } - c->executive_task = executive_task;// It waits for this to be filled-in: $LK,"executive_task",A="FF:::/Kernel/MultiProc.CC,executive_task"$ + c->executive_task = executive_task;// It waits for this to be filled-in: $LK,"executive_task",A="FF:::/Kernel/MultiProc.ZC,executive_task"$ return c; } @@ -230,7 +230,7 @@ CJob *JobQueue(I64 (*fp_addr)(U8 *data), U8 *data=NULL, I64 target_cpu=1, I64 fl I64 job_code=JOBT_CALL, U8 *aux_str=NULL, I64 aux1=0, I64 aux2=0) {//Queue multicore jobs, handled by Executive tasks. //Set flags to zero if you wish to get the res. - //See $LK,"::/Demo/MultiCore/Lock.CC"$ + //See $LK,"::/Demo/MultiCore/Lock.ZC"$ CJobCtrl *ctrl; CJob *tmpc; CTask *executive; @@ -301,7 +301,7 @@ U0 CoreAPExecutiveInit() } U0 Core0StartMP() -{//Called by sys_task during $LK,"start-up",A="FF:::/Kernel/KMain.CC,Core0StartMP"$. +{//Called by sys_task during $LK,"start-up",A="FF:::/Kernel/KMain.ZC,Core0StartMP"$. CTask *task; U8 buf[STR_LEN]; CAP16BitInit *mp = MP_VECT_ADDR; diff --git a/src/Kernel/PCI.CC b/src/Kernel/PCI.ZC similarity index 100% rename from src/Kernel/PCI.CC rename to src/Kernel/PCI.ZC diff --git a/src/Kernel/PCIBIOS.CC b/src/Kernel/PCIBIOS.ZC similarity index 100% rename from src/Kernel/PCIBIOS.CC rename to src/Kernel/PCIBIOS.ZC diff --git a/src/Kernel/QuickSort.CC b/src/Kernel/QuickSort.ZC similarity index 96% rename from src/Kernel/QuickSort.CC rename to src/Kernel/QuickSort.ZC index 08870363..ba70ef1a 100755 --- a/src/Kernel/QuickSort.CC +++ b/src/Kernel/QuickSort.ZC @@ -5,7 +5,7 @@ fp_compare() passes by value instead of ref. For ascending strings: return StrCompare(e1,e2); For ascending ints : return e1-e2; -Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.CC"$. +Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.ZC"$. */ I64 i, *left, *right, pivot; @@ -103,7 +103,7 @@ For ascending strings: return StrCompare(*e1,*e2); For ascending ints : return *e1-*e2; Don't return e1-e2 if numbers can overflow, return -1,0 or 1. -Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.CC"$. +Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.ZC"$. */ U8 *tmp; diff --git a/src/Kernel/Sched.CC b/src/Kernel/Sched.ZC similarity index 100% rename from src/Kernel/Sched.CC rename to src/Kernel/Sched.ZC diff --git a/src/Kernel/SerialDev/Keyboard.CC b/src/Kernel/SerialDev/Keyboard.ZC similarity index 100% rename from src/Kernel/SerialDev/Keyboard.CC rename to src/Kernel/SerialDev/Keyboard.ZC diff --git a/src/Kernel/SerialDev/MakeSerialDev.CC b/src/Kernel/SerialDev/MakeSerialDev.ZC similarity index 100% rename from src/Kernel/SerialDev/MakeSerialDev.CC rename to src/Kernel/SerialDev/MakeSerialDev.ZC diff --git a/src/Kernel/SerialDev/Message.CC b/src/Kernel/SerialDev/Message.ZC similarity index 99% rename from src/Kernel/SerialDev/Message.CC rename to src/Kernel/SerialDev/Message.ZC index 7dc141d9..143c0fce 100755 --- a/src/Kernel/SerialDev/Message.CC +++ b/src/Kernel/SerialDev/Message.ZC @@ -109,7 +109,7 @@ I64 FlushMessages(CTask *task=NULL) I64 MessageGet(I64 *_arg1=NULL, I64 *_arg2=NULL, I64 mask=~1, CTask *task=NULL) {//Wait for a message of type specified by a one in the mask. //Throw-out all messages not in mask. - //Returns $LK,"message_code",A="MN:MESSAGE_CMD"$. See $LK,"::/Demo/MessageLoop.CC"$. + //Returns $LK,"message_code",A="MN:MESSAGE_CMD"$. See $LK,"::/Demo/MessageLoop.ZC"$. I64 res; if (!task) diff --git a/src/Kernel/SerialDev/Mouse.CC b/src/Kernel/SerialDev/Mouse.ZC similarity index 99% rename from src/Kernel/SerialDev/Mouse.CC rename to src/Kernel/SerialDev/Mouse.ZC index 97963b89..f81cc9a5 100755 --- a/src/Kernel/SerialDev/Mouse.CC +++ b/src/Kernel/SerialDev/Mouse.ZC @@ -1,5 +1,5 @@ U0 GridInit() -{//Init mouse grid struct. See $LK,"::/Demo/Graphics/Grid.CC"$. +{//Init mouse grid struct. See $LK,"::/Demo/Graphics/Grid.ZC"$. mouse_grid.x = mouse_grid.y = mouse_grid.z = 8; mouse_grid.x_offset = mouse_grid.y_offset = mouse_grid.z_offset = 0; mouse_grid.x_speed = mouse_grid.y_speed = mouse_grid.z_speed = 1; @@ -45,7 +45,7 @@ U0 MouseUpdate(I64 x, I64 y, I64 z, Bool l, Bool r) } U0 MouseSet(I64 x=I64_MAX, I64 y=I64_MAX, I64 z=I64_MAX, I64 l=I64_MAX, I64 r=I64_MAX) -{//Note: Generates a message. See $LK,"MouseSet",A="FF:::/Demo/Games/Zing.CC,MouseSet"$(). +{//Note: Generates a message. See $LK,"MouseSet",A="FF:::/Demo/Games/Zing.ZC,MouseSet"$(). if (!(0 <= x < sys_vbe_mode.width)) x = mouse.pos.x; if (!(0 <= y < sys_vbe_mode.height)) diff --git a/src/Kernel/StrA.CC b/src/Kernel/StrA.ZC similarity index 100% rename from src/Kernel/StrA.CC rename to src/Kernel/StrA.ZC diff --git a/src/Kernel/StrB.CC b/src/Kernel/StrB.ZC similarity index 98% rename from src/Kernel/StrB.CC rename to src/Kernel/StrB.ZC index 3817c4d2..89bb0cfb 100755 --- a/src/Kernel/StrB.CC +++ b/src/Kernel/StrB.ZC @@ -148,7 +148,7 @@ U0 FlagsScan(U8 *_dst_flags, U8 *list, U8 *src) {/*More than 64 flags. Flags passed by ref. Examples: -$LK,"FlagsScan",A="FF:::/System/Utils/Find.CC,FlagsScan:2"$(&fuf_flags,Define("ST_FILE_UTIL_FLAGS"),fu_flags); +$LK,"FlagsScan",A="FF:::/System/Utils/Find.ZC,FlagsScan:2"$(&fuf_flags,Define("ST_FILE_UTIL_FLAGS"),fu_flags); I64 flags=0; FlagsScan(&flags,"R\0L\0Dump\0Scan\0","+Dump-R"); //Sets Bit#2, Clears Bit#0. diff --git a/src/Kernel/StrPrint.CC b/src/Kernel/StrPrint.ZC similarity index 100% rename from src/Kernel/StrPrint.CC rename to src/Kernel/StrPrint.ZC diff --git a/src/Kernel/StrScan.CC b/src/Kernel/StrScan.ZC similarity index 100% rename from src/Kernel/StrScan.CC rename to src/Kernel/StrScan.ZC diff --git a/src/MakeHome.CC b/src/MakeHome.ZC similarity index 100% rename from src/MakeHome.CC rename to src/MakeHome.ZC diff --git a/src/Misc/Auto/AutoDistro.CC b/src/Misc/Auto/AutoDistro.ZC similarity index 90% rename from src/Misc/Auto/AutoDistro.CC rename to src/Misc/Auto/AutoDistro.ZC index 50041543..be0a04c5 100755 --- a/src/Misc/Auto/AutoDistro.CC +++ b/src/Misc/Auto/AutoDistro.ZC @@ -24,7 +24,7 @@ U0 MakeMyISO(U8 *_out_iso_filename) Move(BOOT_DIR_DVD_KERNEL_BIN_C, "/Distro" BOOT_DIR_KERNEL_BIN_C); CopyTree("/Home", "/Distro/Home"); - Del("/Distro/Home/Registry.CC"); + Del("/Distro/Home/Registry.ZC"); CopyTree("/System", "/Distro/System"); Del("/Distro/System/AutoComplete/ACDefs.DATA"); CopyTree("/Compiler", "/Distro/Compiler"); @@ -33,8 +33,8 @@ U0 MakeMyISO(U8 *_out_iso_filename) DirMake("/Distro/Doc"); Copy("/Doc/EdPullDown.DD", "/Distro/Doc/EdPullDown.DD"); Copy("/Doc/Tips.DD", "/Distro/Doc/Tips.DD"); - Copy("/Misc/Auto/Once.CC", "/Distro/Once.CC"); - Copy("/Misc/Auto/HomeSys.CC", "/Distro/HomeSys.CC"); + Copy("/Misc/Auto/Once.ZC", "/Distro/Once.ZC"); + Copy("/Misc/Auto/HomeSys.ZC", "/Distro/HomeSys.ZC"); Del("/Distro/Misc/PCIDevices.DD"); Del("/Distro/Misc/Bible.TXT"); Del("/Distro/Misc/Clementine.TXT"); diff --git a/src/Misc/Auto/AutoFullDistro0.CC b/src/Misc/Auto/AutoFullDistro0.ZC similarity index 100% rename from src/Misc/Auto/AutoFullDistro0.CC rename to src/Misc/Auto/AutoFullDistro0.ZC diff --git a/src/Misc/Auto/AutoFullDistro1.CC b/src/Misc/Auto/AutoFullDistro1.ZC similarity index 100% rename from src/Misc/Auto/AutoFullDistro1.CC rename to src/Misc/Auto/AutoFullDistro1.ZC diff --git a/src/Misc/Auto/AutoFullDistro2.CC b/src/Misc/Auto/AutoFullDistro2.ZC similarity index 94% rename from src/Misc/Auto/AutoFullDistro2.CC rename to src/Misc/Auto/AutoFullDistro2.ZC index c18854f1..6ed4e235 100755 --- a/src/Misc/Auto/AutoFullDistro2.CC +++ b/src/Misc/Auto/AutoFullDistro2.ZC @@ -12,7 +12,7 @@ U0 MakeMyISO() return; } - DocTreeFWrite("/System/Define.CC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", line_count); + DocTreeFWrite("/System/Define.ZC", "LineRep", "DefinePrint(\"DD_ZEALOS_LOC\",\"%,d\");\n", line_count); DefinePrint("DD_ZEALOS_LOC", "%,d", line_count); "Total LOC:%12,d\n\n", line_count; @@ -36,7 +36,7 @@ U0 MakeMyISO() progress1++; CopyTree("/Home", "/Distro/Home"); progress1++; - Del("/Distro/Home/Registry.CC"); + Del("/Distro/Home/Registry.ZC"); CopyTree("/System", "/Distro/System"); progress1++; CopyTree("/Apps", "/Distro/Apps"); diff --git a/src/Misc/Auto/AutoInstall.CC b/src/Misc/Auto/AutoInstall.ZC similarity index 91% rename from src/Misc/Auto/AutoInstall.CC rename to src/Misc/Auto/AutoInstall.ZC index 14c2064b..355ae251 100755 --- a/src/Misc/Auto/AutoInstall.CC +++ b/src/Misc/Auto/AutoInstall.ZC @@ -11,14 +11,14 @@ U0 InstallDrive(U8 drv_let) ExePrint("DirMake(\"%C:/Tmp/ScreenShots\");", drv_let); ExePrint("DirMake(\"%C:/Home\");", drv_let); - st = MStrPrint("%C:/Home/DoDistro.CC", drv_let); + st = MStrPrint("%C:/Home/DoDistro.ZC", drv_let); if (!FileFind(st)) - Copy("::/Misc/DoDistro.CC", st); + Copy("::/Misc/DoDistro.ZC", st); Free(st); - st = MStrPrint("%C:/Home/MakeHome.CC", drv_let); + st = MStrPrint("%C:/Home/MakeHome.ZC", drv_let); if (!FileFind(st)) - Copy("::/MakeHome.CC", st); + Copy("::/MakeHome.ZC", st); Free(st); } @@ -96,7 +96,7 @@ U0 VMInstallWiz() BootMHDIns('C'); } - Copy("::/Misc/Auto/BootMHD2.CC", "C:/System/Boot/BootMHD2.CC"); + Copy("::/Misc/Auto/BootMHD2.ZC", "C:/System/Boot/BootMHD2.ZC"); //////////////////////////////////// diff --git a/src/Misc/Auto/BootMHD2.CC b/src/Misc/Auto/BootMHD2.ZC similarity index 97% rename from src/Misc/Auto/BootMHD2.CC rename to src/Misc/Auto/BootMHD2.ZC index 1c333c19..a1410cfa 100755 --- a/src/Misc/Auto/BootMHD2.CC +++ b/src/Misc/Auto/BootMHD2.ZC @@ -117,6 +117,6 @@ BMHD2_HISTART: BMHD2_OLD_CS_RIP: DU16 0, 0; BMHD2_END:: -//Continues here $LK,"::/System/Boot/BootHD.CC",A="FF:::/System/Boot/BootHD.CC,START"$ +//Continues here $LK,"::/System/Boot/BootHD.ZC",A="FF:::/System/Boot/BootHD.ZC,START"$ #assert BMHD2_END - BMHD2_START < MODULE_SIZE } diff --git a/src/Misc/Auto/HomeSys.CC b/src/Misc/Auto/HomeSys.ZC similarity index 100% rename from src/Misc/Auto/HomeSys.CC rename to src/Misc/Auto/HomeSys.ZC diff --git a/src/Misc/Auto/Once.CC b/src/Misc/Auto/Once.ZC similarity index 83% rename from src/Misc/Auto/Once.CC rename to src/Misc/Auto/Once.ZC index a3a8ac2c..2ad35116 100755 --- a/src/Misc/Auto/Once.CC +++ b/src/Misc/Auto/Once.ZC @@ -1,9 +1,9 @@ -// Custom temporary Once.CC used by Auto ISO process. +// Custom temporary Once.ZC used by Auto ISO process. //This file is executed by the //first terminal window upon start-up. -//See $LK,"Once",A="FF:~/HomeSys.CC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. +//See $LK,"Once",A="FF:~/HomeSys.ZC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. U0 Tmp() { diff --git a/src/Misc/DoDistro.CC b/src/Misc/DoDistro.ZC similarity index 92% rename from src/Misc/DoDistro.CC rename to src/Misc/DoDistro.ZC index 1ab92923..3f877a9b 100755 --- a/src/Misc/DoDistro.CC +++ b/src/Misc/DoDistro.ZC @@ -25,7 +25,7 @@ U0 MakeMyISO(U8 *_out_iso_filename) // CopyTree(BOOT_DIR, "/Distro" BOOT_DIR); CopyTree("/Home", "/Distro/Home"); - Del("/Distro/Home/Registry.CC"); + Del("/Distro/Home/Registry.ZC"); CopyTree("/System", "/Distro/System"); CopyTree("/Apps", "/Distro/Apps"); CopyTree("/Compiler", "/Distro/Compiler"); @@ -50,4 +50,4 @@ U0 MakeMyISO(U8 *_out_iso_filename) MakeMyISO("/Tmp/MyDistro.ISO.C"); -// Study the account examples $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$. +// Study the account examples $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.ZC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.ZC,1"$. diff --git a/src/Misc/OSInstall.CC b/src/Misc/OSInstall.ZC similarity index 97% rename from src/Misc/OSInstall.CC rename to src/Misc/OSInstall.ZC index 5fbd025d..36aced0c 100755 --- a/src/Misc/OSInstall.CC +++ b/src/Misc/OSInstall.ZC @@ -49,7 +49,7 @@ U0 OSFilesMergeInner(CDirEntry *tmpde1, CDirEntry *tmpde2, I64 *_fuf_flags, I64 } U0 OSFilesMerge(U8 *dst_files_find_mask="/*", U8 *src_files_find_mask="/*", U8 *fu_flags=NULL) -{ // See $LK+PU,"Merge",A="FF:::/System/Utils/Merge.CC,public U0 Merge"$. +{ // See $LK+PU,"Merge",A="FF:::/System/Utils/Merge.ZC,public U0 Merge"$. I64 df_flags = 0, fuf_flags = 0; CDirEntry *tmpde1 = NULL, *tmpde2 = NULL; @@ -163,14 +163,14 @@ U0 InstallDrive(U8 drv_let) ExePrint("DirMake(\"%C:/Tmp/ScreenShots\");", drv_let); ExePrint("DirMake(\"%C:/Home\");", drv_let); - st = MStrPrint("%C:/Home/DoDistro.CC", drv_let); + st = MStrPrint("%C:/Home/DoDistro.ZC", drv_let); if (!FileFind(st)) - Copy("::/Misc/DoDistro.CC", st); + Copy("::/Misc/DoDistro.ZC", st); Free(st); - st = MStrPrint("%C:/Home/MakeHome.CC", drv_let); + st = MStrPrint("%C:/Home/MakeHome.ZC", drv_let); if (!FileFind(st)) - Copy("::/MakeHome.CC", st); + Copy("::/MakeHome.ZC", st); Free(st); } diff --git a/src/Misc/OSTestSuite.CC b/src/Misc/OSTestSuite.ZC similarity index 100% rename from src/Misc/OSTestSuite.CC rename to src/Misc/OSTestSuite.ZC diff --git a/src/Misc/Tour/Tour3.IN b/src/Misc/Tour/Tour3.IN index 806c3b2c..b2b50478 100755 --- a/src/Misc/Tour/Tour3.IN +++ b/src/Misc/Tour/Tour3.IN @@ -21,7 +21,7 @@ TourPut( "Now, we're going to edit a file. Normally, " "type it on the command line.\n\n" "$$GREEN$$$$FG$$ to complete the command.\n"); -InPrint(25, "Ed(\"CastleFrankenstein.CC\");"); +InPrint(25, "Ed(\"CastleFrankenstein.ZC\");"); InGetStr("\n"); Message(MESSAGE_KEY_DOWN_UP, 0, SC_CURSOR_UP | SCF_CTRL); @@ -41,7 +41,7 @@ TourPut("Press $$GREEN$$$$FG$$ to abort the editor.\n"); InCharGet(CH_ESC,CH_SHIFT_ESC); -TourPut("Now, run the CastleFrankenstein.CC program. Press $$GREEN$$$$FG$$.\n"); +TourPut("Now, run the CastleFrankenstein.ZC program. Press $$GREEN$$$$FG$$.\n"); InPrint(25, "#include \"CastleFrankenstein\";"); InGetStr("\n"); @@ -66,7 +66,7 @@ TourPut( "$$GREEN$$$$FG$$\tExtended ASCII.\n" "$$GREEN$$$$FG$$\tTerminal window.\n" "$$GREEN$$$$FG$$\tKill task (window).\n", TRUE); -InPrint(50, "Ed(\"CastleFrankenstein.CC\");\n"); +InPrint(50, "Ed(\"CastleFrankenstein.ZC\");\n"); TourPut("Press $$GREEN$$$$FG$$ in the editor to run the file being edited.\n"); diff --git a/src/Misc/Tour/Tour4.IN b/src/Misc/Tour/Tour4.IN index c662ac0c..2454f3c4 100755 --- a/src/Misc/Tour/Tour4.IN +++ b/src/Misc/Tour/Tour4.IN @@ -2,7 +2,7 @@ Message(MESSAGE_KEY_DOWN, 0, SC_CURSOR_DOWN | SCF_CTRL); "\nCd(\"::/Demo/Games\");Dir;\n"; -TourPut( "Now, we're going to add the CastleFrankenstein.CC program " +TourPut( "Now, we're going to add the CastleFrankenstein.ZC program " "to your PersonalMenu.\n\n" "Press $$GREEN$$$$FG$$ to get to your PersonalMenu.\n"); InCharGet(CH_CTRLM); diff --git a/src/Misc/Tour/Tour7.IN b/src/Misc/Tour/Tour7.IN index 10433292..421fe5f4 100755 --- a/src/Misc/Tour/Tour7.IN +++ b/src/Misc/Tour/Tour7.IN @@ -44,7 +44,7 @@ Sleep(2000); TourPut("Notice the number of matches.\n",TRUE); -TourPut( "The wrapper function is in your $$RED$$~/HomeWrappers.CC$$FG$$ file. " +TourPut( "The wrapper function is in your $$RED$$~/HomeWrappers.ZC$$FG$$ file. " "There is a function $$RED$$$$TX+L+PU+UL,\"R\",A=\"MN:R\"$$$$FG$$() for " "find and replace. Feel free to customize.\n", TRUE); @@ -54,7 +54,7 @@ TourPut("Press $$GREEN$$$$FG$$.\n"); Message(MESSAGE_KEY_DOWN, 0, SC_CURSOR_DOWN | SCF_CTRL); "\n"; -"Ed(\"~/HomeWrappers.CC\");"; +"Ed(\"~/HomeWrappers.ZC\");"; InGetStr("\n"); TourPut("Press $$GREEN$$$$FG$$ to abort the source code.\n"); diff --git a/src/Once.CC b/src/Once.ZC similarity index 93% rename from src/Once.CC rename to src/Once.ZC index be0b6d7b..c45446b2 100755 --- a/src/Once.CC +++ b/src/Once.ZC @@ -3,7 +3,7 @@ //This file is executed by the //first terminal window upon start-up. -//See $LK,"Once",A="FF:~/HomeSys.CC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. +//See $LK,"Once",A="FF:~/HomeSys.ZC,Once"$ and $LK,"Home Files",A="FF:::/Doc/GuideLines.DD,/Home Files"$. //Delete the rest from this file. diff --git a/src/PersonalMenu.DD b/src/PersonalMenu.DD index 6b909d324919124df64639400c9830f33cada5c7..5fbfc47cbb5ebcb1ef803dfcef59b42733cc2d4b 100755 GIT binary patch delta 30 icmezVoB8{1<_%kz7^60CW$FS^4y+!mK&q1~?=t|@+6+Vh delta 30 icmezVoB8{1<_%kz7@aq7W$FS^4y+!mK&q1~?=t|=SquLF diff --git a/src/StartOS.CC b/src/StartOS.ZC similarity index 94% rename from src/StartOS.CC rename to src/StartOS.ZC index 6b4be193..0409e0dc 100755 --- a/src/StartOS.CC +++ b/src/StartOS.ZC @@ -1,5 +1,5 @@ //This is executed by the System task at boot. -//See $LK,"System Start-up",A="FF:::/Kernel/KMain.CC,\"StartOS"$. +//See $LK,"System Start-up",A="FF:::/Kernel/KMain.ZC,\"StartOS"$. #help_index "Compiler/Directive" public extern I8i Option(I64i num, I8i val); diff --git a/src/System/AutoComplete/ACDictGen.CC b/src/System/AutoComplete/ACDictGen.ZC similarity index 100% rename from src/System/AutoComplete/ACDictGen.CC rename to src/System/AutoComplete/ACDictGen.ZC diff --git a/src/System/AutoComplete/ACFill.CC b/src/System/AutoComplete/ACFill.ZC similarity index 100% rename from src/System/AutoComplete/ACFill.CC rename to src/System/AutoComplete/ACFill.ZC diff --git a/src/System/AutoComplete/ACInit.CC b/src/System/AutoComplete/ACInit.ZC similarity index 100% rename from src/System/AutoComplete/ACInit.CC rename to src/System/AutoComplete/ACInit.ZC diff --git a/src/System/AutoComplete/ACTask.CC b/src/System/AutoComplete/ACTask.ZC similarity index 100% rename from src/System/AutoComplete/ACTask.CC rename to src/System/AutoComplete/ACTask.ZC diff --git a/src/System/AutoComplete/MakeAC.CC b/src/System/AutoComplete/MakeAC.ZC similarity index 100% rename from src/System/AutoComplete/MakeAC.CC rename to src/System/AutoComplete/MakeAC.ZC diff --git a/src/System/BlkDev/DiskCheck.CC b/src/System/BlkDev/DiskCheck.ZC similarity index 100% rename from src/System/BlkDev/DiskCheck.CC rename to src/System/BlkDev/DiskCheck.ZC diff --git a/src/System/BlkDev/DiskPart.CC b/src/System/BlkDev/DiskPart.ZC similarity index 100% rename from src/System/BlkDev/DiskPart.CC rename to src/System/BlkDev/DiskPart.ZC diff --git a/src/System/BlkDev/FileMgr.CC b/src/System/BlkDev/FileMgr.ZC similarity index 100% rename from src/System/BlkDev/FileMgr.CC rename to src/System/BlkDev/FileMgr.ZC diff --git a/src/System/BlkDev/MakeZBlkDev.CC b/src/System/BlkDev/MakeZBlkDev.ZC similarity index 100% rename from src/System/BlkDev/MakeZBlkDev.CC rename to src/System/BlkDev/MakeZBlkDev.ZC diff --git a/src/System/BlkDev/Mount.CC b/src/System/BlkDev/Mount.ZC similarity index 97% rename from src/System/BlkDev/Mount.CC rename to src/System/BlkDev/Mount.ZC index 5e5f0eac..9f1c5e02 100755 --- a/src/System/BlkDev/Mount.CC +++ b/src/System/BlkDev/Mount.ZC @@ -146,7 +146,7 @@ public I64 SATARep(I64 bd_type=BDT_NULL) #help_index "Install;File/Cmd Line (Typically);Cmd Line (Typically);" U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) -{//If _doc, called by $LK,"::/Kernel/KConfig.CC"$ else called by $LK,"Mount",A="MN:Mount"$(). +{//If _doc, called by $LK,"::/Kernel/KConfig.ZC"$ else called by $LK,"Mount",A="MN:Mount"$(). I64 count, total = 0, num_hints, drv_let, type, prt_num, port; U8 blks_buf[STR_LEN], addr_buf[STR_LEN], port_str[STR_LEN], *filename = NULL, *filename2 = NULL, res = 0; @@ -184,7 +184,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) { whole_drive = FALSE; if (_doc) - { //Called by $LK,"::/Kernel/KConfig.CC"$ + { //Called by $LK,"::/Kernel/KConfig.ZC"$ doc = _doc; make_free = FALSE; } @@ -218,7 +218,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) case BDT_ATAPI: num_hints = SATARep(type); if (type == BDT_ATAPI && boot_drive_let) - " to use booted CD/DVD\n"; //Only $LK,"::/Kernel/KConfig.CC"$ + " to use booted CD/DVD\n"; //Only $LK,"::/Kernel/KConfig.ZC"$ do { if (num_hints) @@ -264,7 +264,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) if (!*port_str && _doc) { DocPrint(doc, "\"AHCIBootDVDProbeAll(bd);\n\";\n"); - DocPrint(doc, "AHCIBootDVDProbeAll(bd);\n"); //Only $LK,"::/Kernel/KConfig.CC"$ + DocPrint(doc, "AHCIBootDVDProbeAll(bd);\n"); //Only $LK,"::/Kernel/KConfig.ZC"$ if (drv_let == boot_drive_let) make_free = TRUE; @@ -281,7 +281,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) } DocPrint(doc, "\"BlkDevAdd(bd, 0x%0X, %Z, %Z);\n\";\n", prt_num, whole_drive, "ST_FALSE_TRUE", make_free, "ST_FALSE_TRUE"); DocPrint(doc, "BlkDevAdd(bd, 0x%0X, %d, %d);\n", prt_num, whole_drive, make_free); - if (_doc) //Called by $LK,"::/Kernel/KConfig.CC"$ + if (_doc) //Called by $LK,"::/Kernel/KConfig.ZC"$ count++; else { //Called by $LK,"Mount",A="MN:Mount"$() @@ -300,7 +300,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) } total += count; } - while (count && !_caller_is_prtdisk || !total && _doc); //At least 1 if Called by $LK,"::/Kernel/KConfig.CC"$ + while (count && !_caller_is_prtdisk || !total && _doc); //At least 1 if Called by $LK,"::/Kernel/KConfig.ZC"$ Free(filename); Free(filename2); @@ -309,7 +309,7 @@ U8 Mount2(U8 boot_drive_let, CDoc *_doc, Bool _caller_is_prtdisk) } public U8 Mount(Bool caller_is_prtdisk=FALSE) -{//Mount drives. Called from $LK,"DiskPart(Mount)",A="FF:::/System/BlkDev/DiskPart.CC,Mount("$. +{//Mount drives. Called from $LK,"DiskPart(Mount)",A="FF:::/System/BlkDev/DiskPart.ZC,Mount("$. return Mount2(0, NULL, caller_is_prtdisk); } diff --git a/src/System/BlkDev/ZDiskA.CC b/src/System/BlkDev/ZDiskA.ZC similarity index 98% rename from src/System/BlkDev/ZDiskA.CC rename to src/System/BlkDev/ZDiskA.ZC index 20211016..84930fff 100755 --- a/src/System/BlkDev/ZDiskA.CC +++ b/src/System/BlkDev/ZDiskA.ZC @@ -3,7 +3,7 @@ public U8 *BlkDump(I64 blk, Bool write=FALSE) {//Dump disk block. Optionally, write. //If you set write to TRUE, the block will //be written when you press . - //See $LK,"::/Demo/Disk/DiskRaw.CC"$. + //See $LK,"::/Demo/Disk/DiskRaw.ZC"$. U8 *buf = MAlloc(BLK_SIZE); BlkRead(Fs->cur_dv, buf, blk, 1); @@ -25,7 +25,7 @@ public U8 *ClusDump(I64 c, Bool write=FALSE, I64 num=0) {//Dump disk cluster. Optionally, write. //If you set write to TRUE, the cluster will //be written when you press . - //See $LK,"::/Demo/Disk/DiskRaw.CC"$. + //See $LK,"::/Demo/Disk/DiskRaw.ZC"$. //Do $LK,"Dir",A="MN:Dir"$("*",TRUE); to get cluster numbers of files. U8 *buf = MAlloc(Fs->cur_dv->spc << BLK_SIZE_BITS); diff --git a/src/System/BlkDev/ZDiskB.CC b/src/System/BlkDev/ZDiskB.ZC similarity index 100% rename from src/System/BlkDev/ZDiskB.CC rename to src/System/BlkDev/ZDiskB.ZC diff --git a/src/System/Boot/BootDVD.CC b/src/System/Boot/BootDVD.CC deleted file mode 100755 index 5b22ff67..00000000 --- a/src/System/Boot/BootDVD.CC +++ /dev/null @@ -1,183 +0,0 @@ -#define BOOT_HIGH_LOC_DVD ((BOOT_RAM_LIMIT - (BOOT_STACK_SIZE + DVD_BOOT_LOADER_SIZE)) >> 4) - -DefinePrint("DD_BOOT_HIGH_LOC_DVD", "%08X", BOOT_HIGH_LOC_DVD << 4); -DefinePrint("DD_BOOT_HIGH_LOC_DVD_END", "%08X", BOOT_RAM_LIMIT - 1); - -asm { -USE16 -BDVD_START:: -//DL is supposed to have the BIOS drive number - CLD - MOV AX, BOOT_HIGH_LOC_DVD - MOV ES, AX - - CLI - MOV SS, AX - MOV SP, BOOT_STACK_SIZE + DVD_BOOT_LOADER_SIZE - STI - - CALL BDVD_GET_RIP -BDVD_GET_RIP: - POP BX - SUB BX, BDVD_GET_RIP - BDVD_START - SHR BX, 4 -//This copies this bootloader's code to 0x$TX,"00096600",D="DD_BOOT_HIGH_LOC_DVD"$ - MOV AX, CS - ADD AX, BX - MOV DS, AX - MOV CX, DVD_BOOT_LOADER_SIZE - XOR SI, SI - XOR DI, DI - REP_MOVSB - - MOV AX, BOOT_HIGH_LOC_DVD - MOV DS, AX - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_HIGH_LOC_DVD:BDVD_MAIN - DU16 BDVD_MAIN - BDVD_START, BOOT_HIGH_LOC_DVD; - -BDVD_BIOS_DRIVE_NUM: DU8 0; -BDVD_PAGE: DU8 0; - -BDVD_DAP: DU8 16, 0, 1, 0; //One block at a time -BDVD_DAP_BUF: DU16 0, 0; -BDVD_DAP_BLK: DU64 0; - -BDVD_ZEALOS_MESSAGE: DU8 "Loading ZealOS", 0; - -BDVD_NOT64_MESSAGE: DU8 "ZealOS requires a 64-bit capable processor.\n\r", 0; - -//These get patched. -BDVD_BLK_LO:: DU16 0; -BDVD_BLK_HI:: DU16 0; -BDVD_BLK_COUNT:: DU16 0; -BDVD_SHIFT_BLKS:: DU16 0; -BDVD_PROGRESS_STEP:: DU32 0; -BDVD_PROGRESS_VAL:: DU32 0; - -BDVD_PUT_CHAR:: - MOV AH, 0xE - MOV BL, 7 //Might be foreground color on some BIOS's - MOV BH, U8 [BDVD_PAGE - BDVD_START] - INT 0x10 -BDVD_RET:: - RET -BDVD_PUTS:: -@@1: LODSB - TEST AL, AL - JZ BDVD_RET - CALL BDVD_PUT_CHAR - JMP @@1 - -BDVD_MAIN:: - MOV U8 [BDVD_BIOS_DRIVE_NUM - BDVD_START], DL //Passed in by BIOS - - MOV AH, 0xF - INT 0x10 - MOV U8 [BDVD_PAGE - BDVD_START], BH //Video page - - MOV EAX, 0x80000000 - CPUID - CMP EAX, 0x80000001 - JB @@05 - - MOV EAX, 0x80000001 - CPUID - BT EDX, 29 - JC @@15 -@@05: MOV SI, BDVD_NOT64_MESSAGE - BDVD_START - CALL BDVD_PUTS -@@10: JMP @@10 - -@@15: MOV SI, BDVD_ZEALOS_MESSAGE - BDVD_START - CALL BDVD_PUTS - - MOV AX, BOOT_RAM_BASE / 16 - MOV ES, AX - XOR ECX, ECX - MOV CX, U16 [BDVD_BLK_COUNT - BDVD_START] - - MOV EAX, (80 - 7 - 9) * 65536 //80 columns - XOR EDX, EDX - DIV ECX - MOV U32 [BDVD_PROGRESS_STEP - BDVD_START], EAX - MOV U32 [BDVD_PROGRESS_VAL - BDVD_START], 0 - - MOV AX, U16 [BDVD_BLK_LO - BDVD_START] - MOV DX, U16 [BDVD_BLK_HI - BDVD_START] - -@@20: PUSH CX //Block count - -//READ BLOCK - PUSH AX //Block lo - PUSH DX //Block hi - PUSH ES //Buf seg - MOV U16 [BDVD_DAP_BLK - BDVD_START], AX - MOV U16 [BDVD_DAP_BLK + 2 - BDVD_START], DX - MOV AX, ES - MOV U16 [BDVD_DAP_BUF + 2 - BDVD_START], AX //ES:0000 - MOV SI, BDVD_DAP - BDVD_START //DS:SI=DAP - MOV AH, 0x42 - MOV DL, U8 [BDVD_BIOS_DRIVE_NUM - BDVD_START] - INT 0x13 - - POP AX //ES - ADD AX, DVD_BLK_SIZE / 16 - MOV ES, AX - POP DX - POP AX - INC AX - JNZ @@25 - INC DX - -@@25: PUSH AX - MOV BX, U16 [BDVD_PROGRESS_VAL + 2 - BDVD_START] - MOV EAX, U32 [BDVD_PROGRESS_STEP - BDVD_START] - ADD U32 [BDVD_PROGRESS_VAL - BDVD_START], EAX - CMP U16 [BDVD_PROGRESS_VAL + 2 - BDVD_START], BX - JE @@30 - MOV AL, '.' - CALL BDVD_PUT_CHAR -@@30: POP AX - - POP CX - LOOP @@20 - -//Shift backward to align - PUSH DS - MOV BX, U16 [BDVD_SHIFT_BLKS - BDVD_START] - SHL BX, BLK_SIZE_BITS - 4 - MOV CX, U16 [BDVD_BLK_COUNT - BDVD_START] - MOV AX, BOOT_RAM_BASE / 16 - MOV ES, AX - ADD AX, BX - MOV DS, AX -@@35: PUSH CX - XOR SI, SI - XOR DI, DI - MOV CX, DVD_BLK_SIZE / 4 - REP_MOVSD - MOV AX, DS - ADD AX, DVD_BLK_SIZE / 16 - MOV DS, AX - MOV AX, ES - ADD AX, DVD_BLK_SIZE / 16 - MOV ES, AX - POP CX - LOOP @@35 - POP DS - -//See $LK,"AHCIBootDVDProbeAll",A="MN:AHCIBootDVDProbeAll"$(). - MOV EBX, U32 [BDVD_BLK_LO - BDVD_START] - MOV AX, U16 [BDVD_SHIFT_BLKS - BDVD_START] - SHL EAX, 16 - MOV AX, BOOT_SRC_DVD //$MA-X+PU,"See sys_boot_src",LM="Find(\"sys_boot_src\",\"/*\");View;\n"$ - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_RAM_BASE:0000 - DU16 0, BOOT_RAM_BASE / 16; -//Continues here $LK,"::/Kernel/KStart16.CC",A="FL:::/Kernel/KStart16.CC,1"$ -BDVD_END:: -#assert BDVD_END-BDVD_START < DVD_BOOT_LOADER_SIZE -} diff --git a/src/System/Boot/BootDVDIns.CC b/src/System/Boot/BootDVDIns.CC deleted file mode 100755 index 0005e59c..00000000 --- a/src/System/Boot/BootDVDIns.CC +++ /dev/null @@ -1,35 +0,0 @@ -//See $LK,"Install Documentation",A="FI:::/Doc/Install.DD"$. -//Study the account examples: $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$ - -#include "BootDVD" -#include "DiskISORedSea" - -#help_index "Install" - -#define KERNEL_BIN_C "Kernel.BIN.C" -#define BOOT_DIR "/Boot" -#define BOOT_DIR_DVD_KERNEL_BIN_C BOOT_DIR "/DVD" KERNEL_BIN_C - -U0 MakeAll() -{ - if (Comp("/Compiler/Compiler", "Compiler",, ':')) - throw; - if (Comp("/Kernel/Kernel", "Kernel",, ':')) - throw; -} - -public U0 BootDVDIns(U8 drv_let=0) -{//See $LK,"::/Misc/DoDistro.CC"$. - try - { - if (!Drive(drv_let)) - throw; - MakeAll; - Move("/Kernel/Kernel.BIN", BOOT_DIR_DVD_KERNEL_BIN_C); - } - catch - { - PutExcept; - Beep; - } -} diff --git a/src/System/Boot/BootHD.CC b/src/System/Boot/BootHD.CC deleted file mode 100755 index 9e0097b7..00000000 --- a/src/System/Boot/BootHD.CC +++ /dev/null @@ -1,91 +0,0 @@ -#define MODULE_SIZE 1 * BLK_SIZE -#define BOOT_HIGH_LOC_HD ((BOOT_RAM_LIMIT - (BOOT_STACK_SIZE + MODULE_SIZE)) >> 4) - -DefinePrint("DD_BOOT_HIGH_LOC_HD", "%08X", BOOT_HIGH_LOC_HD << 4); - -asm { -USE16 -BHD_CODE:: - -#define BHD_START (BHD_CODE - offset(CFAT32Boot.code)) - - CLD - - MOV AX, BOOT_HIGH_LOC_HD - MOV ES, AX - - CLI - MOV SS, AX - MOV SP, BOOT_STACK_SIZE + MODULE_SIZE - STI - - CALL BHD_GET_RIP -BHD_GET_RIP: - POP BX - SUB BX, BHD_GET_RIP - BHD_START - SHR BX, 4 -//This copies this bootloader's code to 0x$TX,"00096C00",D="DD_BOOT_HIGH_LOC_HD"$ - MOV AX, CS - ADD AX, BX - MOV DS, AX - MOV CX, MODULE_SIZE - XOR SI, SI - XOR DI, DI - REP_MOVSB - - MOV AX, BOOT_HIGH_LOC_HD - MOV DS, AX - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_HIGH_LOC_HD:BHD_HISTART - DU16 BHD_HISTART - BHD_START, BOOT_HIGH_LOC_HD; - -BHD_BIOS_DRIVE_NUM: DU8 0; - -//Gets patched by $LK,"BootHDIns",A="MN:BootHDIns"$(). -BHD_BLK_COUNT:: DU16 0; - -BHD_DAP: DU8 16, 0, 1, 0; //One block at a time -BHD_DAP_BUF: DU16 0, 0; -//Gets patched by $LK,"BootHDIns",A="MN:BootHDIns"$(). -BHD_DAP_BLK:: //64-bit -BHD_DAP_BLK_LO: DU32 0; -BHD_DAP_BLK_HI: DU32 0; - -BHD_HISTART: - MOV U8 [BHD_BIOS_DRIVE_NUM - BHD_START], DL //Passed in by BIOS - MOV AX, BOOT_RAM_BASE / 16 - MOV ES, AX - XOR ECX, ECX - MOV CX, U16 [BHD_BLK_COUNT - BHD_START] - -@@05: PUSH CX //Block count - -//READ BLOCK - PUSH ES //Buf seg - MOV AX, ES - MOV U16 [BHD_DAP_BUF + 2 - BHD_START], AX //ES:0000 - MOV SI, BHD_DAP - BHD_START //DS:SI=DAP - MOV AH, 0x42 - MOV DL, U8 [BHD_BIOS_DRIVE_NUM - BHD_START] - INT 0x13 - - POP AX //ES - ADD AX, BLK_SIZE / 16 - MOV ES, AX - INC U32 [BHD_DAP_BLK_LO - BHD_START] - JNZ @@10 - INC U32 [BHD_DAP_BLK_HI - BHD_START] - -@@10: POP CX - LOOP @@05 - - XOR EBX, EBX - MOV EAX, BOOT_SRC_HARDDRIVE //$MA-X+PU,"See sys_boot_src",LM="Find(\"sys_boot_src\",\"/*\");View;\n"$ -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_RAM_BASE:0000 - DU16 0, BOOT_RAM_BASE / 16; -//Continues here $LK,"::/Kernel/KStart16.CC",A="FL:::/Kernel/KStart16.CC,1"$ -BHD_END:: -#assert BHD_END - BHD_START < MODULE_SIZE - 2 -} diff --git a/src/System/Boot/BootHDIns.CC b/src/System/Boot/BootHDIns.CC deleted file mode 100755 index c2e2cccd..00000000 --- a/src/System/Boot/BootHDIns.CC +++ /dev/null @@ -1,84 +0,0 @@ -//See $LK,"Install Documentation",A="FI:::/Doc/Install.DD"$. -//Study the account examples: $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$ - -#include "BootHD" - -#help_index "Install" - -#define KERNEL_BIN_C "Kernel.BIN.C" -#define BOOT_DIR "/Boot" -#define BOOT_DIR_KERNEL_BIN_C BOOT_DIR "/" KERNEL_BIN_C - -U0 CompComp() -{ - if (Comp("/Compiler/Compiler", "Compiler",, ':')) - throw; -} - -U0 MakeAll() -{ - CompComp; - if (Comp("/Kernel/Kernel", "Kernel",, ':')) - throw; -} - -public U0 BootHDIns(U8 drv_let=0) -{//$LK,"MakeAll",A="MN:MakeAll"$ and install new boot-loader. - CDrive *drive; - CFAT32Boot br; - CDirEntry de; - I64 i; - - try - { - if (!Drive(drv_let)) - throw; - - drive = Fs->cur_dv; - MakeAll; - - switch (Letter2BlkDevType(drive->drv_let)) - { - case BDT_RAM: - case BDT_ATA: - Move("/Kernel/Kernel.BIN", BOOT_DIR_KERNEL_BIN_C); - - if (!FileFind(BOOT_DIR_KERNEL_BIN_C, &de, FUF_JUST_FILES)) - "No Kernel.BIN.C\n"; - else - { - Free(de.full_name); - "Modifying partition boot record.\n"; - BlkRead(drive, &br, drive->drv_offset, 1); - - br.jump_and_nop[0] = OC_JMP_REL8; - br.jump_and_nop[1] = offset(CFAT32Boot.code) - 2; - -#assert offset(CFAT32Boot.code) >= offset(CRedSeaBoot.code) - - br.jump_and_nop[2] = OC_NOP; - *BHD_BLK_COUNT(U16 *) = (de.size + BLK_SIZE - 1) >> BLK_SIZE_BITS; - *BHD_DAP_BLK(I64 *) = Clus2Blk(drive, de.clus); - - for (i = 0; i < BHD_END - BHD_CODE; i++) - br.code[i] = BHD_CODE(U8 *)[i]; - -#assert sizeof(CFAT32Boot.code) >= BHD_END - BHD_CODE - - for (; i < sizeof(CFAT32Boot.code); i++) - br.code[i] = 0; - - BlkWrite(drive, &br, drive->drv_offset, 1); - } - break; - - default: - throw; - } - } - catch - { - PutExcept; - Beep; - } -} diff --git a/src/System/Boot/BootMHD.CC b/src/System/Boot/BootMHD.CC deleted file mode 100755 index a4168b60..00000000 --- a/src/System/Boot/BootMHD.CC +++ /dev/null @@ -1,105 +0,0 @@ -#define MODULE_SIZE 1 * BLK_SIZE -#define BOOT_HIGH_LOC_MHD ((BOOT_RAM_LIMIT - (BOOT_STACK_SIZE + MODULE_SIZE)) >> 4) - -DefinePrint("DD_BOOT_HIGH_LOC_MHD", "%08X", BOOT_HIGH_LOC_MHD << 4); - -asm { -USE16 -BMHD_START:: -BMHD_CODE:: - CLD - - MOV AX, BOOT_HIGH_LOC_MHD - - CLI - MOV SS, AX - MOV SP, BOOT_STACK_SIZE + MODULE_SIZE - STI - - PUSHF - PUSH DS - PUSH ES - PUSH FS - PUSH GS - PUSH ECX - PUSH EBX - PUSH EDX - PUSH EBP - - MOV ES, AX - - CALL BMHD_GET_RIP -BMHD_GET_RIP: - POP BX - SUB BX, BMHD_GET_RIP-BMHD_START - MOV CX, BX - SHR BX, 4 -//This copies this bootloader's code to 0x$TX,"00096C00",D="DD_BOOT_HIGH_LOC_MHD"$ - MOV AX, CS - PUSH AX - ADD AX, BX - MOV DS, AX - MOV U16 [BMHD_OLD_CS_RIP - BMHD_START], CX - POP U16 [BMHD_OLD_CS_RIP + 2 - BMHD_START] - - MOV CX, MODULE_SIZE - XOR SI, SI - XOR DI, DI - REP_MOVSB - - MOV AX, BOOT_HIGH_LOC_MHD - MOV DS, AX - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_HIGH_LOC_MHD:BMHD_HISTART - DU16 BMHD_HISTART - BMHD_START, BOOT_HIGH_LOC_MHD; - -BMHD_BIOS_DRIVE_NUM: DU8 0; -BMHD_OLD_CS_RIP: DU16 0, 0; -//Gets patched by $LK,"BootHDIns",A="MN:BootHDIns"$(). -BMHD_BLK_COUNT:: DU16 0; - -BMHD_DAP: DU8 16, 0, 1, 0; //One block at a time -BMHD_DAP_BUF: DU16 0, 0; -//Gets patched by $LK,"BootHDIns",A="MN:BootHDIns"$(). -BMHD_DAP_BLK:: //64-bit -BMHD_DAP_BLK_LO: DU32 0; -BMHD_DAP_BLK_HI: DU32 0; - -BMHD_HISTART: - MOV U8 [BMHD_BIOS_DRIVE_NUM - BMHD_START], DL //Passed in by BIOS - MOV AX, BOOT_RAM_BASE / 16 - MOV ES, AX - XOR ECX, ECX - MOV CX, U16 [BMHD_BLK_COUNT - BMHD_START] - -@@05: PUSH CX //Block count - -//READ BLOCK - PUSH ES //Buf seg - MOV AX, ES - MOV U16 [BMHD_DAP_BUF + 2 - BMHD_START], AX //ES:0000 - MOV SI, BMHD_DAP - BMHD_START //DS:SI=DAP - MOV AH, 0x42 - MOV DL, U8 [BMHD_BIOS_DRIVE_NUM - BMHD_START] - INT 0x13 - - POP AX //ES - ADD AX, BLK_SIZE / 16 - MOV ES, AX - INC U32 [BMHD_DAP_BLK_LO - BMHD_START] - JNZ @@10 - INC U32 [BMHD_DAP_BLK_HI - BMHD_START] - -@@10: POP CX - LOOP @@05 - - MOV DL, U8 [BMHD_BIOS_DRIVE_NUM - BMHD_START] - MOV EBX, U32 [BMHD_OLD_CS_RIP - BMHD_START] -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_RAM_BASE:0000 - DU16 0, BOOT_RAM_BASE / 16; -//Continues here $LK,"BMHD2_START",A="FF:::/System/Boot/BootMHD2.CC,BMHD2_START"$ -BMHD_END:: -#assert BMHD_END-BMHD_START <= 440 -} diff --git a/src/System/Boot/BootMHD2.CC b/src/System/Boot/BootMHD2.CC deleted file mode 100755 index 6eafbc22..00000000 --- a/src/System/Boot/BootMHD2.CC +++ /dev/null @@ -1,121 +0,0 @@ -#define MODULE_SIZE 2 * BLK_SIZE -#define BOOT_HIGH_LOC_MHD2 ((BOOT_RAM_LIMIT - (BOOT_STACK_SIZE + MODULE_SIZE)) >> 4) - -DefinePrint("DD_BOOT_HIGH_LOC_MHD2", "%08X", BOOT_HIGH_LOC_MHD2 << 4); - -asm { -USE16 -BMHD2_START:: - MOV U32 FS:[0], 'B' + 0x2000 + ('2' + 0x2000) << 16 - - MOV AX, BOOT_HIGH_LOC_MHD2 - MOV ES, AX -//This copies this bootloader's code to 0x$TX,"00096A00",D="DD_BOOT_HIGH_LOC_MHD2"$ - MOV AX, CS - MOV DS, AX - MOV U32 [BMHD2_OLD_CS_RIP - BMHD2_START], EBX - MOV U8 [BMHD2_BIOS_DRIVE_NUM - BMHD2_START], DL - - MOV CX, MODULE_SIZE - XOR SI, SI - XOR DI, DI - REP_MOVSB - - MOV AX, BOOT_HIGH_LOC_MHD2 - MOV DS, AX - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP BOOT_HIGH_LOC_MHD2:BMHD2_HISTART - DU16 BMHD2_HISTART - BMHD2_START, BOOT_HIGH_LOC_MHD2; - -BMHD2_BOOT_MESSAGE:: - DU8 256 DUP(0); - -BMHD2_BIOS_DRIVE_NUM: DU8 0; -BMHD2_PAGE: DU8 0; -BMHD2_BLK_ARRAY:: DU64 8 DUP(0); - -BMHD2_DAP: DU8 16, 0, 1, 0; //One block at a time -BMHD2_DAP_BUF: DU16 0, 0; -BMHD2_DAP_BLK:: //64-bit -BMHD2_DAP_BLK_LO: DU32 0; -BMHD2_DAP_BLK_HI: DU32 0; - -BMHD2_PUT_CHAR:: - MOV AH, 0xE - MOV BL, 7 //Might be foreground color on some BIOS's - MOV BH, U8 [BMHD2_PAGE - BMHD2_START] - INT 0x10 -BMHD2_RET:: - RET -BMHD2_PUTS:: -@@1: LODSB - TEST AL, AL - JZ BMHD2_RET - CALL BMHD2_PUT_CHAR - JMP @@1 - -BMHD2_GETCHAR: - XOR AH, AH - INT 0x16 - PUSH AX - MOV AH, 0x0E - MOV BX, 0x07 - INT 0x10 - POP AX - RET - -BMHD2_HISTART: - MOV AH, 0xF - INT 0x10 - MOV U8 [BMHD2_PAGE - BMHD2_START], BH //Video page - - MOV U32 FS:[0], 0 -@@5: MOV SI, BMHD2_BOOT_MESSAGE - BMHD2_START - CALL BMHD2_PUTS - CALL BMHD2_GETCHAR - CMP AL, '0' - JB @@5 - CMP AL, '8' - JAE @@5 - AND EAX, 7 - - MOV EBX, U32 BMHD2_BLK_ARRAY - BMHD2_START[EAX * 8] - MOV EAX, U32 BMHD2_BLK_ARRAY + 4 - BMHD2_START[EAX * 8] - - TEST EBX, EBX - JNZ @@10 - TEST EAX, EAX - JZ @@5 - -@@10: MOV U32 [BMHD2_DAP_BLK_LO - BMHD2_START], EBX - MOV U32 [BMHD2_DAP_BLK_HI - BMHD2_START], EAX - - MOV AX, U16 [BMHD2_OLD_CS_RIP - BMHD2_START] - SHR AX, 4 - ADD AX, U16 [BMHD2_OLD_CS_RIP + 2 - BMHD2_START] - MOV U16 [BMHD2_DAP_BUF + 2 - BMHD2_START], AX //ES:0000 - MOV SI, BMHD2_DAP - BMHD2_START //DS:SI=DAP - MOV DL, U8 [BMHD2_BIOS_DRIVE_NUM - BMHD2_START] - MOV AH, 0x42 - INT 0x13 - - POP EBP - POP EDX - POP EBX - POP ECX - XOR EAX, EAX - POP GS - POP FS - POP ES - POP DS - POPF - -//The assembler doesn't support 16-bit very well. - DU8 0xEA; //JMP xxxx:yyyy -BMHD2_OLD_CS_RIP: - DU16 0, 0; -BMHD2_END:: -//Continues here $LK,"::/System/Boot/BootHD.CC",A="FF:::/System/Boot/BootHD.CC,START"$ -#assert BMHD2_END - BMHD2_START < MODULE_SIZE -} diff --git a/src/System/Boot/BootMHDIns.CC b/src/System/Boot/BootMHDIns.CC deleted file mode 100755 index 241dbf30..00000000 --- a/src/System/Boot/BootMHDIns.CC +++ /dev/null @@ -1,180 +0,0 @@ -//See $LK,"Install Documentation",A="FI:::/Doc/Install.DD"$. -//Study the account examples: $LK,"Config Strs",A="FL:::/Demo/AcctExample/TOS/TOSConfig.CC,1"$, $LK,"Update Funs",A="FL:::/Demo/AcctExample/TOS/TOSDistro.CC,1"$ - -#include "BootMHD" -#include "BootMHD2" - -#help_index "Install" - -#define BOOT_DIR "/Boot" -//Stage 2 of master boot loader -#define BOOT_DIR_BOOTMHD2_BIN_C BOOT_DIR "/BootMHD2.BIN.C" -//Old master boot record -#define BOOT_DIR_OLDMBR_BIN_C BOOT_DIR "/OldMBR.BIN.C" - -public U0 BootMHDOldRead(U8 src_drive, U8 dst_drive) -{//Reads MBR from disk drive containing src partition. -//Writes a single block file to dst BOOT_DIR. - CBlkDev *bd = Letter2BlkDev(src_drive); - CDrive *drive; - CMasterBoot mbr; - - Drive(dst_drive); - drive = Fs->cur_dv; - - if (drive->fs_type != FSt_REDSEA && drive->fs_type != FSt_FAT32) - PrintErr("File System Not Supported\n"); - else - { -//Bypass partition bounds-checking - BlkDevLock(bd); - AHCIAtaBlksRead(bd, &mbr, 0, 1); - BlkDevUnlock(bd); - - Drive(dst_drive); - DirMake(BOOT_DIR); - FileWrite(BOOT_DIR_OLDMBR_BIN_C, &mbr, BLK_SIZE); - } -} - -public U0 BootMHDOldWrite(U8 src_drive, U8 dst_drive) -{//Reads OldMBR from src drive BOOT_DIR. -//writes it to the MBR of the drive with dst partition. - CBlkDev *bd = Letter2BlkDev(dst_drive); - CMasterBoot *mbr; - - Drive(src_drive); - - if (mbr = FileRead(BOOT_DIR_OLDMBR_BIN_C)) - { -//Bypass partition bounds-checking - BlkDevLock(bd); - AHCIAtaBlksWrite(bd, mbr, 0, 1); - BlkDevUnlock(bd); - } - Free(mbr); -} - -public U0 BootMHDZero(U8 dst_drive) -{//Set MBR of disk with dst partition to zero. - - //This is dangerous!! - //The ZealOS partitioner doesn't play well - //with other operating systems at this time and you need - //to do this on a drive partitioned by ZealOS - //if you wish to partition with another operating system. - CBlkDev *bd = Letter2BlkDev(dst_drive); - CMasterBoot mbr; - - MemSet(&mbr, 0, BLK_SIZE); -//Bypass partition bounds-checking - BlkDevLock(bd); - AHCIAtaBlksWrite(bd, &mbr, 0, 1); - BlkDevUnlock(bd); -} - -public Bool BootMHDIns(U8 drv_let, U8 *drv_list=NULL) -{//Create new MBR on the disk that has drv_let as a partition. -//Puts stage 2 in BOOT_DIR of drv_let. - CBlkDev *bd, *bd1; - CDrive *drive, *p1; - CMasterBoot mbr; - CDirEntry de; - I64 i, j, size, *_q; - U8 *menu_ptr, *ptr, ch, buf[STR_LEN]; - Bool res = FALSE; - - try - { - if (drv_list) - { - StrCopy(buf, drv_list); - StrUtil(buf, SUF_TO_UPPER); - } - else - { - j = 0; - for (i = 'A'; i <= 'Z'; i++) - buf[j++] = i; - buf[j++] = 0; - } - - Drive(drv_let); - drive = Fs->cur_dv; - - if (drive->fs_type != FSt_REDSEA && drive->fs_type != FSt_FAT32) - PrintErr("File System Not Supported\n"); - else - { - bd = drive->bd; - - if (!FileFind(BOOT_DIR_OLDMBR_BIN_C,, FUF_JUST_FILES)) - BootMHDOldRead(drv_let, drv_let); - - _q = BMHD2_BLK_ARRAY; - MemSet(_q, 0, sizeof(I64) * 8); - menu_ptr = BMHD2_BOOT_MESSAGE; - StrPrint(menu_ptr, "\n\r\n\rZealOS Boot Loader\n\r\n\r"); - j = 0; - - if (FileFind(BOOT_DIR_OLDMBR_BIN_C, &de, FUF_JUST_FILES)) - { - Free(de.full_name); - *_q++ = Clus2Blk(drive, de.clus); - CatPrint(menu_ptr, "0. Old Boot Record\n\r"); - j++; - } - - ptr = buf; - while (ch = *ptr++) - { - if ((p1 = Letter2Drive(ch, FALSE)) && (bd1 = p1->bd) && bd1 == bd) - { - *_q = p1->drv_offset; - "Drive %C:%16X\n", Drive2Letter(p1), *_q; - CatPrint(menu_ptr, "%d. Drive %C\n\r", j++, Drive2Letter(p1)); - _q++; - } - } - CatPrint(menu_ptr, "\n\rSelection:"); - - size = BMHD2_END - BMHD2_START; - FileWrite(BOOT_DIR_BOOTMHD2_BIN_C, BMHD2_START, size); - - if (!FileFind(BOOT_DIR_BOOTMHD2_BIN_C, &de, FUF_JUST_FILES)) - "No Boot Loader Image\n"; - else - { - Free(de.full_name); - - *BMHD_BLK_COUNT(U16 *) = (size + BLK_SIZE - 1) >> BLK_SIZE_BITS; - *BMHD_DAP_BLK(I64 *) = Clus2Blk(drive, de.clus); -//Bypass partition bounds-checking - BlkDevLock(bd); - AHCIAtaBlksRead(bd, &mbr, 0, 1); - - for (i = 0; i < BMHD_END - BMHD_CODE; i++) - mbr.code[i] = BMHD_CODE(U8 *)[i]; - -#assert sizeof(CMasterBoot.code) >= BMHD_END - BMHD_CODE - - for (; i < sizeof(CMasterBoot.code); i++) - mbr.code[i] = 0; - - if (!mbr.media_id) - mbr.media_id = RandU32; - - mbr.zero = 0; - mbr.signature = 0xAA55; - - AHCIAtaBlksWrite(bd, &mbr, 0, 1); - - BlkDevUnlock(bd); - res = TRUE; - } - } - } - catch - PutExcept; - return res; -} diff --git a/src/System/Boot/BootRAM.CC b/src/System/Boot/BootRAM.CC deleted file mode 100755 index a6af49aa..00000000 --- a/src/System/Boot/BootRAM.CC +++ /dev/null @@ -1,59 +0,0 @@ -#help_index "Call" -asm { -_HI_CALL:: - PUSH RBP - MOV RBP, RSP - MOV RAX, U64 16[RBP] - TEST RAX, RAX - JZ @@05 - CALL RAX -@@05: POP RBP - RET1 8 -//************************************ -_HI_MEMCOPY:: - PUSH RBP - MOV RBP, RSP - PUSH RSI - PUSH RDI - CLD - MOV RDI, U64 SF_ARG1[RBP] - MOV RSI, U64 SF_ARG2[RBP] - MOV RCX, U64 SF_ARG3[RBP] - REP_MOVSB - MOV RAX, RDI - POP RDI - POP RSI - POP RBP - RET1 24 -} -_extern _HI_CALL I64 HiCall(U8 *machine_code); -_extern _HI_MEMCOPY U8 *HiMemCopy(U8 *dst, U8 *src, I64 count); - -#help_index "Boot" -public U0 BootRAM(U8 *filename="::" BOOT_DIR_KERNEL_BIN_C) -{//Softboot Kernel.BIN file. No hardware reset. - I64 size; - CKernel *hi_image, *lo_image = mem_boot_base - sizeof(CBinFile), reg *sys_ram_reboot; - do - if (!(hi_image = FileRead(filename, &size))) - return; - while (hi_image < 0x100000); //If alloc from low 640K, just get another copy. - - do - sys_ram_reboot = MAlloc(SYS_RAM_REBOOT_END - SYS_RAM_REBOOT, Fs->code_heap); - while (sys_ram_reboot < 0x100000); - - hi_image->boot_src = BOOT_SRC_RAM; - hi_image->boot_blk = 0; - hi_image->boot_patch_table_base = lo_image(U8 *) + hi_image->h.patch_table_offset; - hi_image->sys_run_level = lo_image->sys_run_level & (RLF_VESA | RLF_16BIT); - MemCopy(&hi_image->start, &lo_image->start, sizeof(CKernel) - offset(CKernel.start)); - - CLI - if (mp_count > 1) - MPHalt; - - HiMemCopy(sys_ram_reboot, SYS_RAM_REBOOT, SYS_RAM_REBOOT_END - SYS_RAM_REBOOT); - HiMemCopy(lo_image, hi_image, size); - HiCall(sys_ram_reboot); -} diff --git a/src/System/Boot/DiskISORedSea.CC b/src/System/Boot/DiskISORedSea.CC deleted file mode 100755 index d0b833a8..00000000 --- a/src/System/Boot/DiskISORedSea.CC +++ /dev/null @@ -1,217 +0,0 @@ -#help_index "File/CD DVD" - -U0 FillU16Palindrome(CPalindromeU16 *dst, U16 w) -{ - dst->big = EndianU16(w); - dst->little = w; -} - -U0 FillU32Palindrome(CPalindromeU32 *dst, I64 d) -{ - dst->big = EndianU32(d); - dst->little = d; -} - -class CElTorito -{ - U16 w[16]; - U8 bootable; // 88=bootable 00=not bootable - U8 media_type; // 0=no emulation 4=hard disk - U16 load_seg; // 0000->07C0 - U8 sys_type; - U8 zero; - U16 sect_count; - U32 load_rba; // start address of virtual disk - U8 zero2[20]; -}; - -U0 RedSeaISO9660Stage1(U8 *iso_filename, U8 *stage2_filename) -{ - CDirEntry de; - CFile *out_file = NULL; - U8 *stage1_buf = CAlloc(DVD_BOOT_LOADER_SIZE); - - if (FileFind(stage2_filename, &de) && (out_file = FOpen(iso_filename, "wc+"))) - { - MemCopy(stage1_buf, BDVD_START, BDVD_END - BDVD_START); - *(BDVD_BLK_LO - BDVD_START + stage1_buf)(U32 *) = de.clus >> 2; - *(BDVD_BLK_COUNT - BDVD_START + stage1_buf)(U16 *) = (de.size + DVD_BLK_SIZE - 1) >> (BLK_SIZE_BITS + 2); - *(BDVD_SHIFT_BLKS - BDVD_START + stage1_buf)(U16 *) = de.clus & 3; - - if (de.clus & 3) - *(BDVD_BLK_COUNT - BDVD_START + stage1_buf)(U16 *) += 1; - - FBlkWrite(out_file, stage1_buf, 20 << 2 + 1 << 2, DVD_BOOT_LOADER_SIZE / BLK_SIZE); - FClose(out_file); - } - Free(stage1_buf); -} - -U0 RedSeaISO9660(U8 *iso_filename, U8 drv_let) -{ - CDrive *drive = Letter2Drive(drv_let); - CISOPriDesc *iso_pri = CAlloc(DVD_BLK_SIZE), - *iso_boot = CAlloc(DVD_BLK_SIZE), - *iso_sup = CAlloc(DVD_BLK_SIZE), - *iso_term = CAlloc(DVD_BLK_SIZE); - I64 iso_size = 0, i, j; - U32 *d; - CElTorito *et = CAlloc(DVD_BLK_SIZE); - U8 *zero_buf = CAlloc(DVD_BLK_SIZE), *st; - CFile *out_file = NULL; - - if (out_file = FOpen(iso_filename, "wc+")) - { - iso_size = FSize(out_file) / DVD_BLK_SIZE; - - for (i = 0; i < drive->bd->drv_offset; i += 4) - FBlkWrite(out_file, zero_buf, i, 4); - - iso_pri->type = ISOT_PRI_VOL_DESC; - StrCopy(iso_pri->id, "CD001"); - iso_pri->version = 1; - FillU16Palindrome(&iso_pri->vol_set_size, 1); - FillU16Palindrome(&iso_pri->vol_seq_num, 1); - FillU16Palindrome(&iso_pri->log_block_size, DVD_BLK_SIZE); - FillU32Palindrome(&iso_pri->vol_space_size, iso_size); - FillU32Palindrome(&iso_pri->root_dir_record, drive->root_clus); - iso_pri->file_structure_version = 1; - StrCopy(iso_pri->publisher_id, "ZealOS RedSea"); - - st = MStrPrint("ZealOS V%0.2f %D %T", sys_os_version, Now, Now); - StrCopy(iso_pri->preparer_id, st); - Free(st); - - MemCopy(iso_sup, iso_pri, DVD_BLK_SIZE); - iso_sup->type = ISOT_SUPPLEMENTARY_DESC; - - iso_boot->type = ISOT_BOOT_RECORD; - StrCopy(iso_boot->id, "CD001"); - iso_boot->version = 1; - StrCopy(iso_boot(U8 *) + 7, "EL TORITO SPECIFICATION"); - - FBlkWrite(out_file, iso_pri, 16 << 2, 4); - iso_term->type = ISOT_TERMINATOR; - StrCopy(iso_term->id, "CD001"); - iso_term->version = 1; - - d = iso_boot(U8 *) + 0x47; - *d = 20 << 2 >> 2; - FBlkWrite(out_file, iso_boot, 17 << 2, 4); - - FBlkWrite(out_file, iso_sup, 18 << 2, 4); - FBlkWrite(out_file, iso_term, 19 << 2, 4); - - et->w[0] = 1; - StrCopy(&et->w[2], "ZealOS"); - et->w[15] = 0xAA55; - - j = 0; - for (i = 0; i < 16; i++) //Checksum - j += et->w[i]; - - et->w[14] = -j; - et->bootable = 0x88; - et->media_type = 0;//0=no emu 2=1.44meg 4=hard drive - et->sect_count = 4; //5 seems like the limit, 4 is safer - et->load_rba = 20 << 2 >> 2 + 1; - FBlkWrite(out_file, et, 20 << 2, 4); - FClose(out_file); - } - Free(zero_buf); - Free(et); - Free(iso_pri); - Free(iso_boot); - Free(iso_sup); - Free(iso_term); -} - -I64 RedSeaISOPass1(CDirEntry *tmpde) -{ - I64 dir_entry_count = 3 + LinkedListCount(tmpde), res = 0; - - while (tmpde) - { - if (tmpde->attr & RS_ATTR_DIR) - { - if (tmpde->sub) - res += RedSeaISOPass1(tmpde->sub); - else - res += BLK_SIZE; //Empty dir - } - else - res += CeilU64(tmpde->size, BLK_SIZE); - - tmpde = tmpde->next; - } - res += CeilU64(dir_entry_count << 6, BLK_SIZE); //Size in bytes - -#assert CDIR_SIZE == 64 - - return res; -} - -public I64 RedSeaISO(U8 *_iso_filename=NULL, U8 *_src_dir, U8 *_stage2_filename=NULL) -{//See $LK,"::/Misc/DoDistro.CC"$. Must be ISO.C - I64 i, res, root_count, root_dir_blks, bitmap_blks, bitmap_blks1; - CDirEntry *tmpde; - U8 buf[STR_LEN], *iso_filename, *src_dir, *stage2_filename; - CDrive *drive = DriveMakeFreeSlot(DriveNextFreeLet('Q')); //First $LK,"BDT_ISO_FILE_WRITE",A="MN:BDT_ISO_FILE_WRITE"$ - CBlkDev *bd = BlkDevNextFreeSlot(drive->drv_let, BDT_ISO_FILE_WRITE); - - if (!IsDir(_src_dir)) - PrintErr("'%s' is not a dir.\n", _src_dir); - else - { - if (!_iso_filename) - _iso_filename = blkdev.default_iso_c_filename; - - iso_filename = ExtChange(_iso_filename, "ISO.C"); - src_dir = DirNameAbs(_src_dir); - - if (_stage2_filename) - { - stage2_filename = FileNameAbs(_stage2_filename); - *stage2_filename = drive->drv_let; - - i = StrLen(src_dir); - if (i != 3) //If not root - i++; //Skip slash - - StrCopy(stage2_filename + 3, stage2_filename + i); - } - else - stage2_filename = NULL; - - tmpde = FilesFind(src_dir, FUF_RECURSE); - root_count = LinkedListCount(tmpde) + 3; - root_dir_blks = CeilU64(root_count << 6, BLK_SIZE) >> BLK_SIZE_BITS; - - if (res = RedSeaISOPass1(tmpde) >> BLK_SIZE_BITS) - { - bd->drv_offset = 19 << 2 + (DVD_BLK_SIZE * 2 + DVD_BOOT_LOADER_SIZE) / BLK_SIZE; - bitmap_blks = 1; - do - { - bitmap_blks1 = bitmap_blks; - bitmap_blks = (res + bitmap_blks + BLK_SIZE << 3 - 1) / BLK_SIZE << 3; - } - while (bitmap_blks != bitmap_blks1); - - bd->max_blk = CeilI64(bd->drv_offset + 1 + bitmap_blks + res, 4); - bd->max_blk--; //Inclusive. - bd->file_disk_name = SysStrNew(iso_filename); - bd->init_root_dir_blks = root_dir_blks; - BlkDevAdd(bd,, TRUE, TRUE); - StrPrint(buf, "%C:/", drive->drv_let); - CopyTree(src_dir, buf, TRUE); - RedSeaISO9660Stage1(iso_filename, stage2_filename); - DriveDel(drive); - BlkDevDel(bd); - } - Free(stage2_filename); - Free(src_dir); - Free(iso_filename); - } - return res; -} diff --git a/src/System/Boot/MakeBoot.CC b/src/System/Boot/MakeBoot.CC deleted file mode 100755 index 45635676..00000000 --- a/src/System/Boot/MakeBoot.CC +++ /dev/null @@ -1,8 +0,0 @@ -Cd(__DIR__);; - -#include "BootDVDIns" -#include "BootHDIns" -#include "BootMHDIns" -#include "BootRAM" - -Cd("..");; diff --git a/src/System/Ctrls/CtrlsA.CC b/src/System/Ctrls/CtrlsA.ZC similarity index 99% rename from src/System/Ctrls/CtrlsA.CC rename to src/System/Ctrls/CtrlsA.ZC index 4d68157d..3b57491a 100755 --- a/src/System/Ctrls/CtrlsA.CC +++ b/src/System/Ctrls/CtrlsA.ZC @@ -366,7 +366,7 @@ U0 LeftClickViewAngles(CCtrl *c, I64 x, I64 y, Bool) } public CCtrl *ViewAnglesNew(CTask *task=NULL) -{//Create view angle ctrl. See $LK,"::/Demo/Graphics/Shading.CC"$. +{//Create view angle ctrl. See $LK,"::/Demo/Graphics/Shading.ZC"$. CCtrl *c; CViewAngles *s; diff --git a/src/System/Ctrls/CtrlsBttn.CC b/src/System/Ctrls/CtrlsBttn.ZC similarity index 97% rename from src/System/Ctrls/CtrlsBttn.CC rename to src/System/Ctrls/CtrlsBttn.ZC index 1004741a..40f42897 100755 --- a/src/System/Ctrls/CtrlsBttn.CC +++ b/src/System/Ctrls/CtrlsBttn.ZC @@ -43,7 +43,7 @@ U0 LeftClickCtrlBttn(CCtrl *c, I64, I64, Bool down) public CCtrl *CtrlBttnNew(I64 x, I64 y, I64 width=-1, I64 height=-1, I64 num_states=1, U8 *state_texts, I32 *state_colors, CCtrlBttnState *_s=NULL) -{//Create button ctrl. See $LK,"::/Apps/Strut/Strut.CC"$. +{//Create button ctrl. See $LK,"::/Apps/Strut/Strut.ZC"$. CCtrl *res; CCtrlBttnState *s; I64 i,j,l; diff --git a/src/System/Ctrls/CtrlsSlider.CC b/src/System/Ctrls/CtrlsSlider.ZC similarity index 100% rename from src/System/Ctrls/CtrlsSlider.CC rename to src/System/Ctrls/CtrlsSlider.ZC diff --git a/src/System/Ctrls/MakeCtrls.CC b/src/System/Ctrls/MakeCtrls.ZC similarity index 100% rename from src/System/Ctrls/MakeCtrls.CC rename to src/System/Ctrls/MakeCtrls.ZC diff --git a/src/System/Debug.CC b/src/System/Debug.ZC similarity index 99% rename from src/System/Debug.CC rename to src/System/Debug.ZC index f263da84..a705e0fe 100755 --- a/src/System/Debug.CC +++ b/src/System/Debug.ZC @@ -1,7 +1,7 @@ #help_index "Debugging/Dump" Bool ClassRep2(CDoc *doc, U8 *_d, U8 *class_name=lastclass, Bool u8_chars, Bool force, I64 depth, I64 max_depth, Bool dynamic, I64 types=HTT_CLASS, I64 offset=0) -{//See $LK,"::/Demo/LastClass.CC"$. +{//See $LK,"::/Demo/LastClass.ZC"$. I64 i, j, stars, *ptr; CMemberList *ml; CDocEntry *doc_e; diff --git a/src/System/Define.CC b/src/System/Define.ZC similarity index 95% rename from src/System/Define.CC rename to src/System/Define.ZC index 31a0002f..ba6abd1a 100755 --- a/src/System/Define.CC +++ b/src/System/Define.ZC @@ -12,7 +12,7 @@ U0 LoadDocDefines() bfh(I64) += bfh->file_size - 1; DefinePrint("DD_KERNEL_END", "%08X", bfh); - //$LK,"DD_BOOT_HIGH_LOC_DVD",A="FF:::/System/Boot/BootDVD.CC,DD_BOOT_HIGH_LOC_DVD"$ + //$LK,"DD_BOOT_HIGH_LOC_DVD",A="FF:::/System/Boot/BootDVD.ZC,DD_BOOT_HIGH_LOC_DVD"$ $TR,"LineRep"$ $ID,2$DefinePrint("DD_ZEALOS_LOC","95,265"); diff --git a/src/System/DevInfo.CC b/src/System/DevInfo.ZC similarity index 100% rename from src/System/DevInfo.CC rename to src/System/DevInfo.ZC diff --git a/src/System/DolDoc/DocBin.CC b/src/System/DolDoc/DocBin.ZC similarity index 100% rename from src/System/DolDoc/DocBin.CC rename to src/System/DolDoc/DocBin.ZC diff --git a/src/System/DolDoc/DocChar.CC b/src/System/DolDoc/DocChar.ZC similarity index 99% rename from src/System/DolDoc/DocChar.CC rename to src/System/DolDoc/DocChar.ZC index 309b5bb4..0efd13ff 100755 --- a/src/System/DolDoc/DocChar.CC +++ b/src/System/DolDoc/DocChar.ZC @@ -712,7 +712,7 @@ ic_form_tab: MemCopy(st, doc_ce->tag, doc_ce->max_col + 1); Free(doc_ce->tag); doc_ce->tag = st; - doc_ce->len = MSize(st) - doc_ce->min_col - 2; //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$ + doc_ce->len = MSize(st) - doc_ce->min_col - 2; //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$ Free(doc_ce->data); doc_ce->data = MAlloc(doc_ce->len + 2, doc->mem_task); } diff --git a/src/System/DolDoc/DocClipBoard.CC b/src/System/DolDoc/DocClipBoard.ZC similarity index 100% rename from src/System/DolDoc/DocClipBoard.CC rename to src/System/DolDoc/DocClipBoard.ZC diff --git a/src/System/DolDoc/DocCodeTools.CC b/src/System/DolDoc/DocCodeTools.ZC similarity index 99% rename from src/System/DolDoc/DocCodeTools.CC rename to src/System/DolDoc/DocCodeTools.ZC index aca9745a..877514cc 100755 --- a/src/System/DolDoc/DocCodeTools.CC +++ b/src/System/DolDoc/DocCodeTools.ZC @@ -544,7 +544,7 @@ U0 EdCodeTools2(CDoc *doc, I64 tool_action, Bool beep=TRUE) else { Free(prj_file); - st = DirFile(doc->filename.name, "Load", "CC"); + st = DirFile(doc->filename.name, "Load", "ZC"); prj_file = FileNameAbs(st); Free(st); if (FileFind(prj_file)) diff --git a/src/System/DolDoc/DocDblBuf.CC b/src/System/DolDoc/DocDblBuf.ZC similarity index 97% rename from src/System/DolDoc/DocDblBuf.CC rename to src/System/DolDoc/DocDblBuf.ZC index 3f023cac..9c293068 100755 --- a/src/System/DolDoc/DocDblBuf.CC +++ b/src/System/DolDoc/DocDblBuf.ZC @@ -42,7 +42,7 @@ public CDoc *DocBorder(CTask *task=NULL) } public CDoc *DocDblBufStart(CTask *task=NULL) -{//See $LK,"::/Demo/Spy.CC"$ +{//See $LK,"::/Demo/Spy.ZC"$ Bool unlock_ddoc; CDoc *pdoc = DocPut(task), *ddoc = DocDisplay(task), *res; @@ -76,7 +76,7 @@ public CDoc *DocDblBufStart(CTask *task=NULL) } public Bool DocDblBufEnd(CTask *task=NULL) -{//See $LK,"::/Demo/Spy.CC"$ +{//See $LK,"::/Demo/Spy.ZC"$ Bool res = FALSE; CDoc *pdoc = DocPut(task), *ddoc = DocDisplay(task); @@ -97,7 +97,7 @@ public Bool DocDblBufEnd(CTask *task=NULL) } public Bool DocDblBufSwap(CTask *task=NULL) -{//See $LK,"::/Demo/Spy.CC"$ +{//See $LK,"::/Demo/Spy.ZC"$ Bool res = FALSE; CDoc *pdoc = DocPut(task), *ddoc = DocDisplay(task); diff --git a/src/System/DolDoc/DocEd.CC b/src/System/DolDoc/DocEd.ZC similarity index 100% rename from src/System/DolDoc/DocEd.CC rename to src/System/DolDoc/DocEd.ZC diff --git a/src/System/DolDoc/DocExterns.CC b/src/System/DolDoc/DocExterns.ZC similarity index 100% rename from src/System/DolDoc/DocExterns.CC rename to src/System/DolDoc/DocExterns.ZC diff --git a/src/System/DolDoc/DocFile.CC b/src/System/DolDoc/DocFile.ZC similarity index 100% rename from src/System/DolDoc/DocFile.CC rename to src/System/DolDoc/DocFile.ZC diff --git a/src/System/DolDoc/DocFind.CC b/src/System/DolDoc/DocFind.ZC similarity index 100% rename from src/System/DolDoc/DocFind.CC rename to src/System/DolDoc/DocFind.ZC diff --git a/src/System/DolDoc/DocForm.CC b/src/System/DolDoc/DocForm.ZC similarity index 97% rename from src/System/DolDoc/DocForm.CC rename to src/System/DolDoc/DocForm.ZC index 103e4ead..bc789307 100755 --- a/src/System/DolDoc/DocForm.CC +++ b/src/System/DolDoc/DocForm.ZC @@ -116,7 +116,7 @@ U0 DocDataFormat(CDoc *doc, CDocEntry *doc_e, I64 d=DOCM_CANCEL) else { ptr2 = MAlloc(i + 8, doc->mem_task); - doc_e->len = MSize(ptr2) - doc_e->min_col - 2; //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$ + doc_e->len = MSize(ptr2) - doc_e->min_col - 2; //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$ MemCopy(ptr2, ptr, i + 1); Free(doc_e->tag); doc_e->tag = ptr2; @@ -262,7 +262,7 @@ U0 DocDataScan(CDoc *doc, CDocEntry *doc_e) #help_index "DolDoc/Input;StdIn/DolDoc" public Bool DocForm(U8 *_d, U8 *class_name=lastclass, I64 dof_flags=0, U8 *header=NULL, U8 *footer=NULL) {//User input. Supply a class name that has format definitions. -//See $LK,"::/Demo/DolDoc/Form.CC"$ and $LK,"::/Demo/LastClass.CC"$. +//See $LK,"::/Demo/DolDoc/Form.ZC"$ and $LK,"::/Demo/LastClass.ZC"$. CMemberList *ml; CDocEntry *doc_e; U8 *format; @@ -300,7 +300,7 @@ public Bool DocForm(U8 *_d, U8 *class_name=lastclass, I64 dof_flags=0, U8 *heade doc_e->len = ml->dim.total_count; if (doc_e->de_flags & DOCEF_HAS_TERMINATOR) doc_e->len--; - Free(doc_e->tag); //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.CC,DataTagWidth"$ + Free(doc_e->tag); //See $LK,"DataTagWidth",A="FA:::/System/DolDoc/DocPlain.ZC,DataTagWidth"$ doc_e->tag = MAlloc(doc_e->len + doc_e->min_col + 2, doc->mem_task); //+2 because "_\0" } } @@ -416,6 +416,6 @@ public I64 PopUpMenu(CDoc *doc, I64 dof_flags=0) } public Bool PopUpForm(U8 *_d, U8 *class_name=lastclass, I64 dof_flags=DOF_SIZE_MIN, U8 *header=NULL, U8 *footer=NULL) -{//See $LK,"::/Demo/DolDoc/Form.CC"$ and $LK,"::/Demo/LastClass.CC"$. +{//See $LK,"::/Demo/DolDoc/Form.ZC"$ and $LK,"::/Demo/LastClass.ZC"$. return PopUpPrint("DocForm(0x%X,0x%X,0x%X,0x%X,0x%X);", _d, class_name, dof_flags, header, footer); } diff --git a/src/System/DolDoc/DocGet.CC b/src/System/DolDoc/DocGet.ZC similarity index 100% rename from src/System/DolDoc/DocGet.CC rename to src/System/DolDoc/DocGet.ZC diff --git a/src/System/DolDoc/DocGr.CC b/src/System/DolDoc/DocGr.ZC similarity index 100% rename from src/System/DolDoc/DocGr.CC rename to src/System/DolDoc/DocGr.ZC diff --git a/src/System/DolDoc/DocHighlight.CC b/src/System/DolDoc/DocHighlight.ZC similarity index 98% rename from src/System/DolDoc/DocHighlight.CC rename to src/System/DolDoc/DocHighlight.ZC index 77bc6a7e..a359299e 100755 --- a/src/System/DolDoc/DocHighlight.CC +++ b/src/System/DolDoc/DocHighlight.ZC @@ -6,7 +6,7 @@ CColorROPU32 highlight_hash_type_colors[HTt_TYPES_NUM] = DOC_COLOR_KEYWORD, DOC_COLOR_KEYWORD, DOC_COLOR_REG, 0, 0, 0, 0}; U32 *DocHighlight(CDocEntry *doc_e, U8 *src, I64 len, I64 _tmp_u32_attr) -{//Be aware of $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.CC"$. +{//Be aware of $LK,"::/Demo/ToHtmlToTXTDemo/ToHtml.ZC"$. U32 *res = MAlloc((len + 1) * sizeof(U32)), *dst = res; U8 *ptr; CDocSettings *s = &doc_e->settings; diff --git a/src/System/DolDoc/DocInit.CC b/src/System/DolDoc/DocInit.ZC similarity index 100% rename from src/System/DolDoc/DocInit.CC rename to src/System/DolDoc/DocInit.ZC diff --git a/src/System/DolDoc/DocLink.CC b/src/System/DolDoc/DocLink.ZC similarity index 100% rename from src/System/DolDoc/DocLink.CC rename to src/System/DolDoc/DocLink.ZC diff --git a/src/System/DolDoc/DocMacro.CC b/src/System/DolDoc/DocMacro.ZC similarity index 100% rename from src/System/DolDoc/DocMacro.CC rename to src/System/DolDoc/DocMacro.ZC diff --git a/src/System/DolDoc/DocNew.CC b/src/System/DolDoc/DocNew.ZC similarity index 99% rename from src/System/DolDoc/DocNew.CC rename to src/System/DolDoc/DocNew.ZC index 36f450d4..b83cc7f4 100755 --- a/src/System/DolDoc/DocNew.CC +++ b/src/System/DolDoc/DocNew.ZC @@ -41,7 +41,7 @@ Bool IsEditableText(CDocEntry *doc_e) } CDocEntry *DocEntryNewBase(CDoc *doc, I64 type, I64 de_flags=0, I64 x=0, I64 y=0, I64 page_line_num=0) -{//See also $LK,"MAllocIdent",A="FF:::/System/DolDoc/DocRecalc.CC,MAllocIdent"$ and $MA-X+PU,"CDocEntry",LM="F(\"sizeof(CDocEntry)\");View;"$. +{//See also $LK,"MAllocIdent",A="FF:::/System/DolDoc/DocRecalc.ZC,MAllocIdent"$ and $MA-X+PU,"CDocEntry",LM="F(\"sizeof(CDocEntry)\");View;"$. CDocEntry *res = CAlloc(sizeof(CDocEntryBase), doc->mem_task); res->type = type; diff --git a/src/System/DolDoc/DocPlain.CC b/src/System/DolDoc/DocPlain.ZC similarity index 100% rename from src/System/DolDoc/DocPlain.CC rename to src/System/DolDoc/DocPlain.ZC diff --git a/src/System/DolDoc/DocPopUp.CC b/src/System/DolDoc/DocPopUp.ZC similarity index 98% rename from src/System/DolDoc/DocPopUp.CC rename to src/System/DolDoc/DocPopUp.ZC index 40e01c0a..b8d31020 100755 --- a/src/System/DolDoc/DocPopUp.CC +++ b/src/System/DolDoc/DocPopUp.ZC @@ -305,10 +305,10 @@ public F64 PopUpRangeF64Log(F64 lo, F64 hi, I64 steps, U8 *format="%9.4f", U8 *h public I64 SysFile(U8 *filename, Bool warn_ext=TRUE) {//Make sys_task execute file. Bool okay = TRUE; - U8 *name = FileNameAbs(filename), *name2 = ExtDefault(name, "CC"); + U8 *name = FileNameAbs(filename), *name2 = ExtDefault(name, "ZC"); I64 res = 0; - if (warn_ext && !FilesFindMatch(name2, FILEMASK_JIT) && !PopUpCancelOk(ST_WARN_ST "Not .CC File\n\n")) + if (warn_ext && !FilesFindMatch(name2, FILEMASK_JIT) && !PopUpCancelOk(ST_WARN_ST "Not .ZC File\n\n")) okay = FALSE; if (okay) res = Sys("#include \"%s\";", name2); @@ -321,10 +321,10 @@ public I64 SysFile(U8 *filename, Bool warn_ext=TRUE) public I64 PopUpFile(U8 *filename, Bool warn_ext=TRUE, CTask *parent=NULL, CTask **_pu_task=NULL) {//$LK,"ExeFile2",A="MN:ExeFile2"$() in $LK,"PopUp",A="MN:PopUp"$ task. Cont as User. Bool okay = TRUE; - U8 *st, *name = FileNameAbs(filename), *name2 = ExtDefault(name, "CC"); + U8 *st, *name = FileNameAbs(filename), *name2 = ExtDefault(name, "ZC"); I64 res = 0; - if (warn_ext && !FilesFindMatch(name2, FILEMASK_JIT) && !PopUpCancelOk(ST_WARN_ST "Not .CC File\n\n")) + if (warn_ext && !FilesFindMatch(name2, FILEMASK_JIT) && !PopUpCancelOk(ST_WARN_ST "Not .ZC File\n\n")) okay = FALSE; if (okay) { @@ -340,7 +340,7 @@ public I64 PopUpFile(U8 *filename, Bool warn_ext=TRUE, CTask *parent=NULL, CTask public I64 PopUpRunFile(U8 *filename, I64 ccf_flags=0, ...) {//$LK,"ExeFile",A="MN:ExeFile"$() with args using $LK,"LastFun",A="MN:LastFun"$() in $LK,"PopUp",A="MN:PopUp"$ task. - U8 *st, *name = FileNameAbs(filename), *name2 = ExtDefault(name, "CC"); + U8 *st, *name = FileNameAbs(filename), *name2 = ExtDefault(name, "ZC"); I64 res = 0; st = MStrPrint("\"$$$$WW+H,1$$$$\"; ExeFile2(\"%s\", 0x%X); LastFun(0x%X, 0x%X);", name2, ccf_flags, argc, argv); diff --git a/src/System/DolDoc/DocPutKey.CC b/src/System/DolDoc/DocPutKey.ZC similarity index 99% rename from src/System/DolDoc/DocPutKey.CC rename to src/System/DolDoc/DocPutKey.ZC index c519aac5..fa782149 100755 --- a/src/System/DolDoc/DocPutKey.CC +++ b/src/System/DolDoc/DocPutKey.ZC @@ -424,7 +424,7 @@ public U0 DocPutKey(CDoc *doc, I64 ch=0, I64 sc=0) else break; } - if (st2 = DirFile(st, "Run", "CC")) + if (st2 = DirFile(st, "Run", "ZC")) { if (FileFind(st2)) { diff --git a/src/System/DolDoc/DocPutS.CC b/src/System/DolDoc/DocPutS.ZC similarity index 100% rename from src/System/DolDoc/DocPutS.CC rename to src/System/DolDoc/DocPutS.ZC diff --git a/src/System/DolDoc/DocRecalc.CC b/src/System/DolDoc/DocRecalc.ZC similarity index 100% rename from src/System/DolDoc/DocRecalc.CC rename to src/System/DolDoc/DocRecalc.ZC diff --git a/src/System/DolDoc/DocRecalcLib.CC b/src/System/DolDoc/DocRecalcLib.ZC similarity index 98% rename from src/System/DolDoc/DocRecalcLib.CC rename to src/System/DolDoc/DocRecalcLib.ZC index 7437ac19..175da6a2 100755 --- a/src/System/DolDoc/DocRecalcLib.CC +++ b/src/System/DolDoc/DocRecalcLib.ZC @@ -205,7 +205,7 @@ public I64 DocMax(I64 i=I64_MAX) //Adjusts the size of the cmd line buf. //Normally, the cmd line deletes entries //when more are added and the old scroll up. - //See $LK,"max_entries",A="FF:::/System/DolDoc/DocTerm.CC,max_entries"$. + //See $LK,"max_entries",A="FF:::/System/DolDoc/DocTerm.ZC,max_entries"$. I64 res; CDoc *doc; diff --git a/src/System/DolDoc/DocRun.CC b/src/System/DolDoc/DocRun.ZC similarity index 100% rename from src/System/DolDoc/DocRun.CC rename to src/System/DolDoc/DocRun.ZC diff --git a/src/System/DolDoc/DocTerm.CC b/src/System/DolDoc/DocTerm.ZC similarity index 98% rename from src/System/DolDoc/DocTerm.CC rename to src/System/DolDoc/DocTerm.ZC index b9178b50..0021095a 100755 --- a/src/System/DolDoc/DocTerm.CC +++ b/src/System/DolDoc/DocTerm.ZC @@ -133,7 +133,7 @@ I64 TermRightClickLink(CDoc *doc, CDocEntry *doc_e) case RIGHT_INCLUDE: if (FileExtDot(st) && !FilesFindMatch(st, FILEMASK_JIT)) { - if (!PopUpCancelOk(ST_WARN_ST "Not .CC File\n\n")) + if (!PopUpCancelOk(ST_WARN_ST "Not .ZC File\n\n")) { send_new_line = TRUE; break; @@ -148,7 +148,7 @@ I64 TermRightClickLink(CDoc *doc, CDocEntry *doc_e) case RIGHT_AINCLUDE: if (FileExtDot(st) && !FilesFindMatch(st, FILEMASK_JIT)) { - if (!PopUpCancelOk(ST_WARN_ST "Not .CC File\n\n")) + if (!PopUpCancelOk(ST_WARN_ST "Not .ZC File\n\n")) { send_new_line = TRUE; break; diff --git a/src/System/DolDoc/DocTree.CC b/src/System/DolDoc/DocTree.ZC similarity index 100% rename from src/System/DolDoc/DocTree.CC rename to src/System/DolDoc/DocTree.ZC diff --git a/src/System/DolDoc/DocWidgetWiz.CC b/src/System/DolDoc/DocWidgetWiz.ZC similarity index 100% rename from src/System/DolDoc/DocWidgetWiz.CC rename to src/System/DolDoc/DocWidgetWiz.ZC diff --git a/src/System/DolDoc/MakeDoc.CC b/src/System/DolDoc/MakeDoc.ZC similarity index 100% rename from src/System/DolDoc/MakeDoc.CC rename to src/System/DolDoc/MakeDoc.ZC diff --git a/src/System/Externs.CC b/src/System/Externs.ZC similarity index 100% rename from src/System/Externs.CC rename to src/System/Externs.ZC diff --git a/src/System/God/GodBible.CC b/src/System/God/GodBible.ZC similarity index 100% rename from src/System/God/GodBible.CC rename to src/System/God/GodBible.ZC diff --git a/src/System/God/GodExterns.CC b/src/System/God/GodExterns.ZC similarity index 100% rename from src/System/God/GodExterns.CC rename to src/System/God/GodExterns.ZC diff --git a/src/System/God/GodSong.CC b/src/System/God/GodSong.ZC similarity index 100% rename from src/System/God/GodSong.CC rename to src/System/God/GodSong.ZC diff --git a/src/System/God/HolySpirit.CC b/src/System/God/HolySpirit.ZC similarity index 100% rename from src/System/God/HolySpirit.CC rename to src/System/God/HolySpirit.ZC diff --git a/src/System/God/MakeGod.CC b/src/System/God/MakeGod.ZC similarity index 100% rename from src/System/God/MakeGod.CC rename to src/System/God/MakeGod.ZC diff --git a/src/System/Gr/Gr.HH b/src/System/Gr/Gr.HH index 2d4ef45c..c3b40407 100755 --- a/src/System/Gr/Gr.HH +++ b/src/System/Gr/Gr.HH @@ -152,8 +152,8 @@ public class CSpritePtMeshU8s : CSpriteBase #help_index "Graphics/Sprite;Sprites;Sprites/Binary" -// See $LK,"Sprites",A="HI:Sprites"$. See $LK,"::/System/Gr/GrSpritePlot.CC",A="FL:::/System/Gr/GrSpritePlot.CC,1"$ and -// $LK,"::/Demo/Graphics/SpriteRaw.CC"$ for how CSprite are stored. +// See $LK,"Sprites",A="HI:Sprites"$. See $LK,"::/System/Gr/GrSpritePlot.ZC",A="FL:::/System/Gr/GrSpritePlot.ZC,1"$ and +// $LK,"::/Demo/Graphics/SpriteRaw.ZC"$ for how CSprite are stored. public class CSprite { CSprite *next,*last; diff --git a/src/System/Gr/GrAsm.CC b/src/System/Gr/GrAsm.ZC similarity index 100% rename from src/System/Gr/GrAsm.CC rename to src/System/Gr/GrAsm.ZC diff --git a/src/System/Gr/GrBitMap.CC b/src/System/Gr/GrBitMap.ZC similarity index 99% rename from src/System/Gr/GrBitMap.CC rename to src/System/Gr/GrBitMap.ZC index d4b7e7d5..baf38404 100755 --- a/src/System/Gr/GrBitMap.CC +++ b/src/System/Gr/GrBitMap.ZC @@ -2101,7 +2101,7 @@ gr_done: public I64 GrHLine(CDC *dc=gr.dc, I64 x1, I64 x2, I64 y, I64 z1=0, I64 z2=0) {//3D. No transformation or thick. //Returns count of pixs changed - //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. + //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 dist, dx, dz, z, res = 0, i, j, d; U8 *dst; CColorROPU32 c, c2, color = dc->color, bkcolor = dc->bkcolor, dither_colors; @@ -2315,7 +2315,7 @@ gr_done: public I64 GrVLine(CDC *dc=gr.dc, I64 x, I64 y1, I64 y2, I64 z1=0, I64 z2=0) {//3D. No transformation or thick. //Returns count of pixs changed - //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. + //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 dist, dy, dz, z, res = 0, i, j, d; U8 *dst; CColorROPU32 c, c2, color = dc->color, bkcolor = dc->bkcolor, dither_colors; diff --git a/src/System/Gr/GrComposites.CC b/src/System/Gr/GrComposites.ZC similarity index 99% rename from src/System/Gr/GrComposites.CC rename to src/System/Gr/GrComposites.ZC index a67f5285..464b342b 100755 --- a/src/System/Gr/GrComposites.CC +++ b/src/System/Gr/GrComposites.ZC @@ -377,7 +377,7 @@ mesh_done: } public U0 DrawWaitMouse(CDC *dc, I64 x, I64 y) -{//This is a callback. See $LK,"::/Demo/Graphics/Grid.CC"$. +{//This is a callback. See $LK,"::/Demo/Graphics/Grid.ZC"$. I64 old_pen_width = dc->thick; CColorROPU32 old_color = dc->color; diff --git a/src/System/Gr/GrDC.CC b/src/System/Gr/GrDC.ZC similarity index 98% rename from src/System/Gr/GrDC.CC rename to src/System/Gr/GrDC.ZC index 320c759b..aa65bc61 100755 --- a/src/System/Gr/GrDC.CC +++ b/src/System/Gr/GrDC.ZC @@ -4,7 +4,7 @@ #define GR_SCALE (1<<32) public U0 Mat4x4MulXYZ(I64 *r, I64 *_x, I64 *_y, I64 *_z) -{//Rotate 3D point using 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Rotate 3D point using 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 x1, y1, z1, xx = *_x, yy = *_y, zz = *_z; x1 = (r[0 * 4 + 0] * xx + r[0 * 4 + 1] * yy + r[0 * 4 + 2] * zz + r[0 * 4 + 3]) >> 32; @@ -17,7 +17,7 @@ public U0 Mat4x4MulXYZ(I64 *r, I64 *_x, I64 *_y, I64 *_z) public U0 DCTransform(CDC *dc, I64 *_x, I64 *_y, I64 *_z) {//This is the default dc->transform() callback. -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. Mat4x4MulXYZ(dc->r, _x, _y, _z); *_x += dc->x; *_y += dc->y; @@ -25,7 +25,7 @@ public U0 DCTransform(CDC *dc, I64 *_x, I64 *_y, I64 *_z) } public I64 *Mat4x4IdentEqu(I64 *r) -{//Set matrix to identity. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Set matrix to identity. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. MemSet(r, 0, sizeof(I64)*16); r[0 * 4 + 0].i32[1] = 1; r[1 * 4 + 1].i32[1] = 1; @@ -36,7 +36,7 @@ public I64 *Mat4x4IdentEqu(I64 *r) } public I64 *Mat4x4IdentNew(CTask *mem_task=NULL) -{//MAlloc an identity matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//MAlloc an identity matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. return Mat4x4IdentEqu(MAlloc(sizeof(I64) * 16, mem_task)); } @@ -49,7 +49,7 @@ public I64 Mat4x4NormSqr65536(I64 *r) } public U0 DCMat4x4Set(CDC *dc=NULL, I64 *r) -{//Set device context's rot matrix. Will be $LK,"Free",A="MN:Free"$d() in $LK,"DCDel",A="MN:DCDel"$().Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Set device context's rot matrix. Will be $LK,"Free",A="MN:Free"$d() in $LK,"DCDel",A="MN:DCDel"$().Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. //The main purpose is to set matrix norm for thick scaling. //NULL as dc means gr.dc if (!dc) @@ -168,7 +168,7 @@ public U0 DCReset(CDC *dc) public U0 DCExtentsInit(CDC *dc=NULL) {//Init markers for extent of next newly drawn graphics. //NULL means gr.dc - //See $LK,"::/Demo/Graphics/Extents.CC"$ + //See $LK,"::/Demo/Graphics/Extents.ZC"$ //You should clear the record flag yourself if (!dc) dc = gr.dc; diff --git a/src/System/Gr/GrEnd.CC b/src/System/Gr/GrEnd.ZC similarity index 100% rename from src/System/Gr/GrEnd.CC rename to src/System/Gr/GrEnd.ZC diff --git a/src/System/Gr/GrExterns.CC b/src/System/Gr/GrExterns.ZC similarity index 100% rename from src/System/Gr/GrExterns.CC rename to src/System/Gr/GrExterns.ZC diff --git a/src/System/Gr/GrGlobals.CC b/src/System/Gr/GrGlobals.ZC similarity index 95% rename from src/System/Gr/GrGlobals.CC rename to src/System/Gr/GrGlobals.ZC index 8c8366ab..07dc2bc3 100755 --- a/src/System/Gr/GrGlobals.CC +++ b/src/System/Gr/GrGlobals.ZC @@ -22,7 +22,7 @@ public class CGrGlobals U0 (*fp_wall_paper)(CTask *task); U0 (*fp_draw_mouse)(CDC *dc, I64 x, I64 y); U0 (*fp_draw_grab_mouse)(CDC *dc, I64 x, I64 y, Bool closed); - U8 *empty_sprite; //Gets assigned $LK,"gr.empty_sprite",A="FF:::/System/Mouse.CC,empty_sprite"$ + U8 *empty_sprite; //Gets assigned $LK,"gr.empty_sprite",A="FF:::/System/Mouse.ZC,empty_sprite"$ #define GR_PEN_BRUSHES_NUM 64 CDC *pen_brushes [GR_PEN_BRUSHES_NUM], @@ -43,7 +43,7 @@ public class CGrGlobals public CBGR24 gr_palette[COLORS_NUM]; -//See $LK,"RLf_VESA",A="FF:::/Kernel/KStart16.CC,RLf_VESA"$ +//See $LK,"RLf_VESA",A="FF:::/Kernel/KStart16.ZC,RLf_VESA"$ //See $LK,"SysGrInit",A="MN:SysGrInit"$() //Allows consts to be used instead of variables. HashPublic("GR_WIDTH", HTT_DEFINE_STR);; diff --git a/src/System/Gr/GrInitA.CC b/src/System/Gr/GrInitA.ZC similarity index 100% rename from src/System/Gr/GrInitA.CC rename to src/System/Gr/GrInitA.ZC diff --git a/src/System/Gr/GrInitB.CC b/src/System/Gr/GrInitB.ZC similarity index 100% rename from src/System/Gr/GrInitB.CC rename to src/System/Gr/GrInitB.ZC diff --git a/src/System/Gr/GrMath.CC b/src/System/Gr/GrMath.ZC similarity index 98% rename from src/System/Gr/GrMath.CC rename to src/System/Gr/GrMath.ZC index e9df5e66..c85e627e 100755 --- a/src/System/Gr/GrMath.CC +++ b/src/System/Gr/GrMath.ZC @@ -9,7 +9,7 @@ public Bool Line(U8 *aux_data, I64 x1, I64 y1, I64 z1, I64 x2, I64 y2, I64 z2, Bool (*fp_plot)(U8 *aux, I64 x, I64 y, I64 z), I64 step=1, I64 start=0) {//Step through line segment calling callback. -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 i, j, d, dx = x2 - x1, dy = y2 - y1, dz = z2 - z1, _x, _y, _z, adx = AbsI64(dx), ady = AbsI64(dy), adz = AbsI64(dz); Bool first = TRUE; @@ -102,7 +102,7 @@ public Bool Line(U8 *aux_data, I64 x1, I64 y1, I64 z1, I64 x2, I64 y2, I64 z2, #help_index "Graphics/Math/3D Transformation" public I64 *Mat4x4MulMat4x4Equ(I64 *dst, I64 *m1, I64 *m2) -{//Multiply 4x4 matrices and store in dst. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Multiply 4x4 matrices and store in dst. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. //Conceptually, the transform m1 is applied after m2 I64 i, j, k; F64 sum; @@ -122,7 +122,7 @@ public I64 *Mat4x4MulMat4x4Equ(I64 *dst, I64 *m1, I64 *m2) } public I64 *Mat4x4MulMat4x4New(I64 *m1, I64 *m2, CTask *mem_task=NULL) -{//Multiply 4x4 matrices. Return MAlloced matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Multiply 4x4 matrices. Return MAlloced matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. //Conceptually, the transform m1 is applied after m2 return Mat4x4MulMat4x4Equ(MAlloc(sizeof(I64) * 16, mem_task), m1, m2); } @@ -140,7 +140,7 @@ public I64 *Mat4x4New(I64 *src, CTask *mem_task=NULL) } public I64 *Mat4x4RotX(I64 *m, F64 è) -{//Rot matrix about X axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Rot matrix about X axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. F64 my_cos = Cos(è) * GR_SCALE, my_sin = Sin(è) * GR_SCALE; I64 r[16], r2[16]; @@ -156,7 +156,7 @@ public I64 *Mat4x4RotX(I64 *m, F64 } public I64 *Mat4x4RotY(I64 *m, F64 ê) -{//Rot matrix about Y axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Rot matrix about Y axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. F64 my_cos = Cos(ê) * GR_SCALE, my_sin = Sin(ê) * GR_SCALE; I64 r[16], r2[16]; @@ -172,7 +172,7 @@ public I64 *Mat4x4RotY(I64 *m, F64 } public I64 *Mat4x4RotZ(I64 *m, F64 é) -{//Rot matrix about Z axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Rot matrix about Z axis. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. F64 my_cos=Cos(é)*GR_SCALE, my_sin=Sin(é)*GR_SCALE; I64 r[16], r2[16]; @@ -214,7 +214,7 @@ public U0 DCThickScale(CDC *dc=gr.dc) } public I64 *Mat4x4TranslationEqu(I64 *r, I64 x, I64 y, I64 z) -{//Set translation values in 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Set translation values in 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. r[0 * 4 + 3] = x << 32; r[1 * 4 + 3] = y << 32; r[2 * 4 + 3] = z << 32; @@ -224,7 +224,7 @@ public I64 *Mat4x4TranslationEqu(I64 *r, I64 x, I64 y, I64 z) } public I64 *Mat4x4TranslationAdd(I64 *r, I64 x, I64 y, I64 z) -{//Add translation to 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Add translation to 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. r[0 * 4 + 3] += x << 32; r[1 * 4 + 3] += y << 32; r[2 * 4 + 3] += z << 32; @@ -301,7 +301,7 @@ public Bool DCSymmetry3Set(CDC *dc=gr.dc, I64 x1, I64 y1, I64 z1, I64 x2, I64 y2 } public U0 DCReflect(CDC *dc, I64 *_x, I64 *_y, I64 *_z) -{//Reflect 3D point about device context's symmetry. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Reflect 3D point about device context's symmetry. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 x = *_x << 32, y = *_y << 32, z = *_z << 32, diff --git a/src/System/Gr/GrPalette.CC b/src/System/Gr/GrPalette.ZC similarity index 100% rename from src/System/Gr/GrPalette.CC rename to src/System/Gr/GrPalette.ZC diff --git a/src/System/Gr/GrPrimatives.CC b/src/System/Gr/GrPrimatives.ZC similarity index 99% rename from src/System/Gr/GrPrimatives.CC rename to src/System/Gr/GrPrimatives.ZC index b65a550a..a3fb9f57 100755 --- a/src/System/Gr/GrPrimatives.CC +++ b/src/System/Gr/GrPrimatives.ZC @@ -738,7 +738,7 @@ public Bool Gr3BSpline(CDC *dc=gr.dc, CD3I32 *ctrl, I64 count, Bool closed=FALSE I64 GrLineFat3(CDC *dc=gr.dc, I64 x1, I64 y1, I64 z1, I64 x2, I64 y2, I64 z2, I64 width, I64 start=0) {//Step through line segment calling callback. -//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +//Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 res = 0, i, j, d, dx = x2 - x1, dy = y2 - y1, dz = z2 - z1, _x, _y, _z, d_lo, d_hi, adx = AbsI64(dx), ady = AbsI64(dy), adz = AbsI64(dz); diff --git a/src/System/Gr/GrScreen.CC b/src/System/Gr/GrScreen.ZC similarity index 99% rename from src/System/Gr/GrScreen.CC rename to src/System/Gr/GrScreen.ZC index aa344e04..b9562f54 100755 --- a/src/System/Gr/GrScreen.CC +++ b/src/System/Gr/GrScreen.ZC @@ -402,7 +402,7 @@ U0 GrUpdateScreen32() } U0 GrUpdateScreen() -{//Called by the Window Manager $LK,"HERE",A="FF:::/System/WinMgr.CC,GrUpdateScreen"$, 30 times a second. +{//Called by the Window Manager $LK,"HERE",A="FF:::/System/WinMgr.ZC,GrUpdateScreen"$, 30 times a second. CDC *dc; if (text.is_fb_busy) diff --git a/src/System/Gr/GrSpritePlot.CC b/src/System/Gr/GrSpritePlot.ZC similarity index 100% rename from src/System/Gr/GrSpritePlot.CC rename to src/System/Gr/GrSpritePlot.ZC diff --git a/src/System/Gr/GrTextBase.CC b/src/System/Gr/GrTextBase.ZC similarity index 100% rename from src/System/Gr/GrTextBase.CC rename to src/System/Gr/GrTextBase.ZC diff --git a/src/System/Gr/MakeGr.CC b/src/System/Gr/MakeGr.ZC similarity index 100% rename from src/System/Gr/MakeGr.CC rename to src/System/Gr/MakeGr.ZC diff --git a/src/System/Gr/ScreenCast.CC b/src/System/Gr/ScreenCast.ZC similarity index 100% rename from src/System/Gr/ScreenCast.CC rename to src/System/Gr/ScreenCast.ZC diff --git a/src/System/Gr/SpriteBitMap.CC b/src/System/Gr/SpriteBitMap.ZC similarity index 100% rename from src/System/Gr/SpriteBitMap.CC rename to src/System/Gr/SpriteBitMap.ZC diff --git a/src/System/Gr/SpriteCode.CC b/src/System/Gr/SpriteCode.ZC similarity index 100% rename from src/System/Gr/SpriteCode.CC rename to src/System/Gr/SpriteCode.ZC diff --git a/src/System/Gr/SpriteEd.CC b/src/System/Gr/SpriteEd.ZC similarity index 99% rename from src/System/Gr/SpriteEd.CC rename to src/System/Gr/SpriteEd.ZC index 6922292f..8cc55c8f 100755 --- a/src/System/Gr/SpriteEd.CC +++ b/src/System/Gr/SpriteEd.ZC @@ -1415,7 +1415,7 @@ I64 SpriteEd(CDoc *doc, CDocEntry *doc_ce, I64 x, I64 y, CSprite **_head, I64 *_ #help_index "Graphics/Sprite;Sprites;Graphics/Math/3D Transformation" public U8 *SpriteTransform(U8 *elems, I64 *r) -{//Rotate Sprite using 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{//Rotate Sprite using 4x4 matrix. Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. U8 *res; CSprite *head = Sprite2SpriteQueue(elems); diff --git a/src/System/Gr/SpriteMain.CC b/src/System/Gr/SpriteMain.ZC similarity index 99% rename from src/System/Gr/SpriteMain.CC rename to src/System/Gr/SpriteMain.ZC index d7635504..2057db91 100755 --- a/src/System/Gr/SpriteMain.CC +++ b/src/System/Gr/SpriteMain.ZC @@ -110,7 +110,7 @@ Bool PopUpExtents(I64 *_x1, I64 *_x2, I64 *_y1, I64 *_y2) } U0 SpriteScreenInit(CDC *dc, I64, I64) -{ //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.CC"$. +{ //Uses $LK,"fixed-point",A="FI:::/Demo/Lectures/FixedPoint.ZC"$. I64 xx, yy, old_pen_width = dc->thick; CColorROPU32 old_color = dc->color; diff --git a/src/System/Gr/SpriteMesh.CC b/src/System/Gr/SpriteMesh.ZC similarity index 99% rename from src/System/Gr/SpriteMesh.CC rename to src/System/Gr/SpriteMesh.ZC index 3dbcfc98..106d4378 100755 --- a/src/System/Gr/SpriteMesh.CC +++ b/src/System/Gr/SpriteMesh.ZC @@ -1113,7 +1113,7 @@ If head points to a mesh, it will load it. Returns a newly malloced mesh or NULL. -See $LK,"::/Demo/Graphics/SpritePlot3D.CC"$. +See $LK,"::/Demo/Graphics/SpritePlot3D.ZC"$. $WW,0$*/ CCtrl *c = CtrlFindUnique(Fs, CTRLT_VIEWING_ANGLES); CViewAngles *s, *old_s; diff --git a/src/System/Gr/SpriteNew.CC b/src/System/Gr/SpriteNew.ZC similarity index 99% rename from src/System/Gr/SpriteNew.CC rename to src/System/Gr/SpriteNew.ZC index 7cb1fd93..6fbe9ddf 100755 --- a/src/System/Gr/SpriteNew.CC +++ b/src/System/Gr/SpriteNew.ZC @@ -141,7 +141,7 @@ public U8 *DC2Sprite(CDC *tmpb) } public U8 *SpriteElem2Summary(CSprite *tmpg) -{//Study $LK,"::/Demo/Graphics/SpriteText.CC"$. +{//Study $LK,"::/Demo/Graphics/SpriteText.ZC"$. U8 buf[STR_LEN], buf2[STR_LEN]; I32 *ptr; diff --git a/src/System/Gr/SpriteSideBar.CC b/src/System/Gr/SpriteSideBar.ZC similarity index 100% rename from src/System/Gr/SpriteSideBar.CC rename to src/System/Gr/SpriteSideBar.ZC diff --git a/src/System/Hash.CC b/src/System/Hash.ZC similarity index 100% rename from src/System/Hash.CC rename to src/System/Hash.ZC diff --git a/src/System/InFile.CC b/src/System/InFile.ZC similarity index 100% rename from src/System/InFile.CC rename to src/System/InFile.ZC diff --git a/src/System/MakeSystem.CC b/src/System/MakeSystem.ZC similarity index 100% rename from src/System/MakeSystem.CC rename to src/System/MakeSystem.ZC diff --git a/src/System/Math.CC b/src/System/Math.ZC similarity index 100% rename from src/System/Math.CC rename to src/System/Math.ZC diff --git a/src/System/MathODE.CC b/src/System/MathODE.ZC similarity index 99% rename from src/System/MathODE.CC rename to src/System/MathODE.ZC index 44a34edf..7ba252e7 100755 --- a/src/System/MathODE.CC +++ b/src/System/MathODE.ZC @@ -626,7 +626,7 @@ U0 ODERK5OneStep(CMathODE *ode) F64 ode_alloced_factor = 0.75; U0 ODEsUpdate(CTask *task) -{/* This routine is called by the $LK,"window mgr",A="FF:::/System/Gr/GrScreen.CC,ODEsUpdate"$on a continuous +{/* This routine is called by the $LK,"window mgr",A="FF:::/System/Gr/GrScreen.ZC,ODEsUpdate"$on a continuous basis to allow real-time simulation. It is intended to provide ress good enough for games. It uses a runge-kutta integrator which is a better algorithm than doing it with Euler. diff --git a/src/System/Memory.CC b/src/System/Memory.ZC similarity index 100% rename from src/System/Memory.CC rename to src/System/Memory.ZC diff --git a/src/System/Menu.CC b/src/System/Menu.ZC similarity index 100% rename from src/System/Menu.CC rename to src/System/Menu.ZC diff --git a/src/System/Mouse.CC b/src/System/Mouse.ZC similarity index 89% rename from src/System/Mouse.CC rename to src/System/Mouse.ZC index b5a8398abb452e20de3713becce187b09d81d898..4a976be599012ad5be921fe7e969db8023b0f482 100755 GIT binary patch delta 19 bcmcc3bDL+vU&g47|6Cavqc*!RiL(FzRpfilename.name; @@ -190,7 +190,7 @@ public U0 SysOnceDrive(U8 drv_let=0, U8 *format, ...) } public U0 OnceDrive(U8 drv_let=0, U8 *format, ...) -{//Add User code to drive $LK,"~/Registry.CC"$, executed next boot. +{//Add User code to drive $LK,"~/Registry.ZC"$, executed next boot. U8 *buf = StrPrintJoin(NULL, format, argc, argv); I64 old_drive_let = *sys_registry_doc->filename.name; @@ -204,7 +204,7 @@ public U0 OnceDrive(U8 drv_let=0, U8 *format, ...) } public U0 OnceExe() -{//Execute Once code. Call goes in $LK,"~/Once.CC"$. +{//Execute Once code. Call goes in $LK,"~/Once.ZC"$. try { diff --git a/src/System/Sound.CC b/src/System/Sound.ZC similarity index 100% rename from src/System/Sound.CC rename to src/System/Sound.ZC diff --git a/src/System/TaskSettings.CC b/src/System/TaskSettings.ZC similarity index 100% rename from src/System/TaskSettings.CC rename to src/System/TaskSettings.ZC diff --git a/src/System/Training.CC b/src/System/Training.ZC similarity index 100% rename from src/System/Training.CC rename to src/System/Training.ZC diff --git a/src/System/Utils/BinRep.CC b/src/System/Utils/BinRep.ZC similarity index 97% rename from src/System/Utils/BinRep.CC rename to src/System/Utils/BinRep.ZC index a2137357..8956875f 100755 --- a/src/System/Utils/BinRep.CC +++ b/src/System/Utils/BinRep.ZC @@ -26,7 +26,7 @@ DefineListLoad("ST_BIN_FILE_TYPES", "END\0" public Bool BinRep(U8 *filename) {//Reports imports, exports, etc for a .BIN file -//See $LK,"Patch Table Generation",A="FF:::/Compiler/CMain.CC,IET_ABS_ADDR"$ and $LK,"Load",A="MN:Load"$(). +//See $LK,"Patch Table Generation",A="FF:::/Compiler/CMain.ZC,IET_ABS_ADDR"$ and $LK,"Load",A="MN:Load"$(). U8 *fbuf, *ptr, *sptr, *absname; I64 i, j, size, etype; Bool res = FALSE; diff --git a/src/System/Utils/CPURep.CC b/src/System/Utils/CPURep.ZC similarity index 100% rename from src/System/Utils/CPURep.CC rename to src/System/Utils/CPURep.ZC diff --git a/src/System/Utils/ConversionScript.CC b/src/System/Utils/ConversionScript.ZC similarity index 97% rename from src/System/Utils/ConversionScript.CC rename to src/System/Utils/ConversionScript.ZC index 24b95d49..38b95151 100755 --- a/src/System/Utils/ConversionScript.CC +++ b/src/System/Utils/ConversionScript.ZC @@ -1,6 +1,6 @@ U0 Cvt(U8 *ff_mask="*", U8 *fu_flags="+r+l-i+S") { - FR(".HC", ".CC", ff_mask); + FR(".HC", ".ZC", ff_mask); Find("MemCpy", ff_mask, fu_flags, "MemCopy"); Find("MemCmp", ff_mask, fu_flags, "MemCompare"); @@ -51,7 +51,7 @@ U0 Cvt(U8 *ff_mask="*", U8 *fu_flags="+r+l-i+S") Find("adam_task", ff_mask, fu_flags, "sys_task"); Find("JobQue", ff_mask, fu_flags, "JobQueue"); Find("MSG_", ff_mask, CatPrint(fu_flags, "-l"), "MESSAGE_"); - Find(".HC", ff_mask, fu_flags, ".CC"); + Find(".HC", ff_mask, fu_flags, ".ZC"); CatPrint(fu_flags, "+l"); Find("Msg", ff_mask, fu_flags, "Message"); Find("MusicSettingsRst",ff_mask, fu_flags, "MusicSettingsReset"); diff --git a/src/System/Utils/Diff.CC b/src/System/Utils/Diff.ZC similarity index 100% rename from src/System/Utils/Diff.CC rename to src/System/Utils/Diff.ZC diff --git a/src/System/Utils/DocUtils.CC b/src/System/Utils/DocUtils.ZC similarity index 100% rename from src/System/Utils/DocUtils.CC rename to src/System/Utils/DocUtils.ZC diff --git a/src/System/Utils/Find.CC b/src/System/Utils/Find.ZC similarity index 100% rename from src/System/Utils/Find.CC rename to src/System/Utils/Find.ZC diff --git a/src/System/Utils/HeapLog.CC b/src/System/Utils/HeapLog.ZC similarity index 100% rename from src/System/Utils/HeapLog.CC rename to src/System/Utils/HeapLog.ZC diff --git a/src/System/Utils/LineRep.CC b/src/System/Utils/LineRep.ZC similarity index 100% rename from src/System/Utils/LineRep.CC rename to src/System/Utils/LineRep.ZC diff --git a/src/System/Utils/LinkCheck.CC b/src/System/Utils/LinkCheck.ZC similarity index 100% rename from src/System/Utils/LinkCheck.CC rename to src/System/Utils/LinkCheck.ZC diff --git a/src/System/Utils/MakeUtils.CC b/src/System/Utils/MakeUtils.ZC similarity index 100% rename from src/System/Utils/MakeUtils.CC rename to src/System/Utils/MakeUtils.ZC diff --git a/src/System/Utils/MemRep.CC b/src/System/Utils/MemRep.ZC similarity index 100% rename from src/System/Utils/MemRep.CC rename to src/System/Utils/MemRep.ZC diff --git a/src/System/Utils/Merge.CC b/src/System/Utils/Merge.ZC similarity index 100% rename from src/System/Utils/Merge.CC rename to src/System/Utils/Merge.ZC diff --git a/src/System/Utils/Profiler.CC b/src/System/Utils/Profiler.ZC similarity index 98% rename from src/System/Utils/Profiler.CC rename to src/System/Utils/Profiler.ZC index 2deeac20..1797c05e 100755 --- a/src/System/Utils/Profiler.CC +++ b/src/System/Utils/Profiler.ZC @@ -9,7 +9,7 @@ I64 pf_buf_in_ptr = 0, pf_depth; I64 pf_prof_active = 0; U0 ProfTimerInt(CTask *task) -{//See $LK,"profiler_timer_irq",A="FF:::/Kernel/KInterrupts.CC,profiler_timer_irq"$. +{//See $LK,"profiler_timer_irq",A="FF:::/Kernel/KInterrupts.ZC,profiler_timer_irq"$. I64 i, k; if (Bt(&pf_prof_active, 0)) diff --git a/src/System/Utils/StrUtils.CC b/src/System/Utils/StrUtils.ZC similarity index 100% rename from src/System/Utils/StrUtils.CC rename to src/System/Utils/StrUtils.ZC diff --git a/src/System/Utils/SysRep.CC b/src/System/Utils/SysRep.ZC similarity index 100% rename from src/System/Utils/SysRep.CC rename to src/System/Utils/SysRep.ZC diff --git a/src/System/Utils/TaskRep.CC b/src/System/Utils/TaskRep.ZC similarity index 100% rename from src/System/Utils/TaskRep.CC rename to src/System/Utils/TaskRep.ZC diff --git a/src/System/Utils/ToDolDoc.CC b/src/System/Utils/ToDolDoc.ZC similarity index 100% rename from src/System/Utils/ToDolDoc.CC rename to src/System/Utils/ToDolDoc.ZC diff --git a/src/System/Utils/ToTXT.CC b/src/System/Utils/ToTXT.ZC similarity index 100% rename from src/System/Utils/ToTXT.CC rename to src/System/Utils/ToTXT.ZC diff --git a/src/System/Utils/VideoRep.CC b/src/System/Utils/VideoRep.ZC similarity index 100% rename from src/System/Utils/VideoRep.CC rename to src/System/Utils/VideoRep.ZC diff --git a/src/System/WallPaper.CC b/src/System/WallPaper.ZC similarity index 100% rename from src/System/WallPaper.CC rename to src/System/WallPaper.ZC diff --git a/src/System/Win.CC b/src/System/Win.ZC similarity index 100% rename from src/System/Win.CC rename to src/System/Win.ZC diff --git a/src/System/WinMgr.CC b/src/System/WinMgr.ZC similarity index 100% rename from src/System/WinMgr.CC rename to src/System/WinMgr.ZC diff --git a/src/System/ZSplash.CC b/src/System/ZSplash.ZC similarity index 100% rename from src/System/ZSplash.CC rename to src/System/ZSplash.ZC