A      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcde f g h i j k l m n o p q r s t u v w x y z { | } ~         !"#$%&'()*+,-./0123456789:;<=>?@Safe9ATRead a time of day string like 17:34:05r in the local time zone and convert that to a UTC time of day. Good for parsing command line args to buildbots.OGet a local time stamp with format YYYYMMDD_HHMMSS. Good for naming files with.+Get the local midnight we've just had as a A.1Get the local midnight that we've just had, as a B.0Get the local midnight we're about to have as a A.0Get the local midnight we're about to have as a B.hCDEFGHIJKLMNOPQRSTUVAWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~BSafe9;AT 4Right justify a doc, padding with a given character. #Right justify a string with spaces. 6Left justify a string, padding with a given character. "Left justify a string with spaces. -Blank text. This is different different from 1 because it comes out a a newline when used in a .Like  but don't display fractional part when the value is < 1000. Good for units where fractional values might not make sense (like bytes).Pretty print an engineering value, to 4 significant figures. Valid range is 10^(-24) (y/yocto) to 10^(+24) (Y/Yotta). Out of range values yield Nothing. examples:  liftM render $ pprEngDouble "J" 102400 ==> Just "1.024MJ" liftM render $ pprEngDouble "s" 0.0000123 ==> Just "12.30us"  F    Safe9ATSGet the names of all files in a directory. This filters out the fake files like  and '..'SGet the names of all the dirs in this one. This filters out the fake files like  and '..'/Get all the files reachable from this directoryDrop out the fake  and '..' dirst from a list of paths.Safe9AMT;Map of event names to their details and build commands. 9Records when an event should start, and when it last ran.JA unique name for this event. Used when writing the schedule to a file.When to run the command. Modifier to the previous.!(When the event was last started, if any."%When the event last finished, if any.$Modifier to when.%aIf the event hasn't been invoked before then do it immediately when we start the cron process.&1Wait until after this time before doing it first.'When to invoke some event.(Just keep doing it.)Don't do it, ever.*)Do it some time after we last started it.+'Do it some time after it last finished.,"Do it each day at this time. The 'days' are UTC days, not local ones.1Given the current time and a list of events, determine which one should be started now. If several events are avaliable then take the one with the earliest start time.2LGiven the current time, decide whether an event could be started. If the $ is %" this always returns true. The  SkipFirst4 modifier is ignored, as this is handled separately.3BGet the list of events in a schedule, ignoring the build commands.4!A nice way to produce a schedule.5AGiven an event name, lookup the associated event from a schedule.6IGiven an event name, lookup the associated build command from a schedule.7Given a new version of an event, update any matching event in the schedule. If the event not already there then return the original schedule. !"#$%&'()*+,-./012345678 !"#$%&'()*+,-./01234567-./0'()*+,$%&# !"1245673 !"#$%&'()*+,-./012345678Safe9AT C:A sequence of lines, without newline charaters on the end.DO(1) No logs here.EO(1) Check if the log is empty.FO(n) Convert a C to a .GO(n) Convert a  to a C.H O(1) Add a B to the start of a C.I O(1) Add a B to the end of a C.J#O(log(min(n1,n2))) Concatenate two Cs.K&O(n) Take the first m lines from a logL%O(n) Take the last m lines from a log BCDEFGHIJKL BCDEFGHIJKL CBDEFGHIJKL BCDEFGHIJKLSafe9ATMNOPMNMNMNOPSafe9ATQ4Bytes of data, pretty printed in engineering format.S6Seconds of time, pretty printed in engineering format. QRSTUVWXYZ[\QRSTSTQR QRSTUVWXYZ[\ Safe9ATe)A range extracted from many-valued data.j&Make statistics from a list of values.k Flatten a e, into a list of its min, avg and max values. efghijklmefghijkefghijkefghijklm Safe9ATpESome static size of the benchmark that isn't affected during the run.r$Some resource used during execution.u&Something that takes time to evaluate.pqrstuvwxyz{|}~pqrstuvwxyz{|}~|}~uvwxyz{rstpqpqrstuvwxyz{|}~ Safe9ATThe comparison of two values.-Comparison of a recent value with a baseline.)A new value that doesn't have a baseline."Make a comparison from two values.  Safe9AT)Gang is running and starting new actions.SGang may be running already started actions, but no new ones are being started.WGang is waiting for currently running actions to finish, but not starting new ones.1Gang is finished, all the actions have completed.5Gang was killed, all the threads are dead (or dying).Abstract gang of threads.+Number of worker threads currently waiting.Get the state of a gang.JBlock until all actions have finished executing, or the gang is killed.gBlock until already started actions have completed, but don't start any more. Gang state changes to .nPause a gang. Actions that have already been started continue to run, but no more will be started until a - command is issued. Gang state changes to .tResume a paused gang, which allows it to continue starting new actions. If the gang was paused it now changes to , otherwise nothing happens.9Kill all the threads in a gang. Gang stage changes to .+Block until the gang is in the given state.Fork a new gang to run the given actions. This function returns immediately, with the gang executing in the background. Gang state starts as  then transitions to 5. To block until all the actions are finished use .Run actions on a gang.[Number of worker threads in the gang / maximum number of actions to execute concurrenty.}Actions to run. They are started in-order, but may finish out-of-order depending on the run time of the individual action. None#9AMTlContinually read lines from a handle and write them to this channel. When the handle hits EOF then write  to the channel.eContinually read lines from some channels and write them to handles. When all the channels return H then we're done. When we're done, signal this fact on the semaphore.Like  , but return the newline charater on the end of the string, if there was one. This allows us to distinguish between lines that were flushed from the IO buffer due to a newline character, and partial lines that were flushed manually, and don't have a newline.2whether the last line ended in a newline characterhandle to read lines fromchannel to write lines toSafe9ATGlobal builder configuration.5Log all system commands executed to this file handle.0Sequence number for generating fresh file names.(Scratch directory for making temp files.The default build config.Safe9ATThe errors we recognise.Some generic errorMSome system command fell over, and it barfed out the given stdout and stderr.#Some miscellanous IO action failed.Some property check? was supposed to return the given boolean value, but it didn't.eA build command needs the following file to continue. This can be used for writing make-like bots.   Safe9AT{The builder monad encapsulates and IO action that can fail with an error, and also read some global configuration info.lRun a build command. The first argument is a directory that can be used for temporary files (like "/tmp")Like o, but report whether it succeeded to the console. If it succeeded then return Just the result, else Nothing.Like  but also takes a .Like  but also takes a .:Discard the resulting value of a compuation. Used like successfully . runBuild ...Throw a needs error saying we needs the given file. A catcher could then usefully create the file, or defer the compuation until it has been created.rLift an IO action into the build monad. If the action throws any exceptions they get caught and turned into  exceptions in our  monad.Like , but with teh monadz.Print some text to stdout.0Print some text to stdout followed by a newline.Print a blank line to stdoutPrint a ----- line to stdout Print a ===== line to stdout Safe9AT Benchmark result.Benchmark definition.A unique name for the benchmarkwSetup command to run before the main benchmark. This does not contribute to the reported time of the overall result.The main command to benchmark.~Check and post-process the result of the main command. This does not contribute to the reported time of the overall result.Run a benchmark a single time.*Run a benchmark the given number of times.*Run a command, returning its elapsed time.Safe9ATSome testable property.UTestable properties are checkable. If the check returns false then throw an error.TTestable properties are checkable. If the check returns true then throw an error.4Check some property while printing what we're doing.4Check some property while printing what we're doing.Safe9AT Alias for  from Control.Monad.Catch.*Log a system command to the handle in our  BuildConfig , if any.'!Safe9AT .Properties of the file system we can test for.'Some executable is in the current path.Some file exists.Some directory exists.Some file is empty._Run a command in a different working directory. Throws an error if the directory doesn't exist.Create a new directory with the given name, run a command within it, then change out and recursively delete the directory. Throws an error if a directory with the given name already exists.=Delete a dir recursively if it's there, otherwise do nothing.RCreate a new directory if it isn't already there, or return successfully if it is.]Create a temp file, pass it to some command, then delete the file after the command finishes.Atomically write a file by first writing it to a tmp file then renaming it. This prevents concurrent processes from reading half-written files.;The file extension for an executable on the current system. Safe9AT$Sleep for a given number of seconds.)Sleep for a given number of milliseconds.None9AMT GRun a system command, returning its exit code and what it wrote to stdout and stderr.NQuietly run a system command, returning its exit code and what it wrote to stdout and stderr.@Run a successful system command, returning what it wrote to stdout and stderr. If the exit code is  then throw an error in the  monad.GQuietly run a successful system command, returning what it wrote to stdout and stderr. If the exit code is  then throw an error in the  monad.@Run a successful system command, returning what it wrote to its stdout . If anything was written to stderr? then treat that as failure. If it fails due to writing to stderr or returning  then throw an error in the  monad.HQuietly run a successful system command, returning what it wrote to its stdout . If anything was written to stderr? then treat that as failure. If it fails due to writing to stderr or returning  then throw an error in the  monad.Like  , but in the  monad.Like  , but in the  monad.Like  , but in the ( monad and throw an error if it returns .Like , but with strings.$Run a system command, returning its  and what was written to stdout and stderr.Whether stdout and stderr+ should be forwarded to the parent process.Command to run.What to pass to the command's stdin. None9AT nList all patches in the given repository. If no repository is given, the current working directory is used. /Retrieve the last N changes from the repository ERetrieve all patches submitted to the repository after the given time               None9AT  8Generic information about the platform we're running on. The environment consists of the  , and some tool versions.?Get the current environment, including versions of these tools.(Get information about the host platform.!Get the name of this host, using uname.!Get the host architecture, using uname.#Get the host processor name, using uname.%Get the host operating system, using uname.-Get the host operating system release, using uname.DGet the version of this GHC, or throw an error if it can't be found. EGet the version of this GCC, or throw an error if it can't be found.  6List of tool names and commands to get their versions. !"      !"None9AT'ZAn external mailer that can send messages. Also contains mail server info if needed.(VSend the mail by writing to the stdin of this command. On many systems the command sendmailh will be aliased to an appropriate wrapper for whatever Mail Transfer Agent (MTA) you have installed.)Send mail via MSMTP, which is a stand-alone SMTP sender. This might be be easier to set up if you don't have a real MTA installed. Get it from http://msmtp.sourceforge.net/-"An email message that we can send.6Create a mail with a given from, to, subject and body. Fill in the date and message id based on the current time. Valid dates and message ids are needed to prevent the mail being bounced by anti-spam systems.7$Render an email message as a string.8Send a mail message.'()*+,-./0123456'from'# field. Should be an email address.'to'# field. Should be an email address. Subject line.Message body.78'()*+,-./012345678-./012345'()*+*,678'()*+*,-./012345678None9AT<!The given host is reachable with ping.=Use wgetN to check if a web-page is gettable. The page is deleted after downloading.;<=>;<=;<=;<=>Safe9AMT@ Given a schedule of commands, run them when their time is due. Only one command is run at a time. If several commands could be started at a specific moment, then we take the one with the earliest potential start time. If any command throws an error in the  monad then the whole loop does.@ !"#$%&'()*+,-./01234567@@@Safe9AT !"#$%&'()*+,-./012345678899:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmmnnopqrstuvwxyz{|}~                                        !!"#$%&''()*+,-./0123456789:;<=>??@ABCDEFGHIJKLMNOPQRSTRUVRWXRWYRWZR[\R[]R[^R[_R[`R[aR[bR[cR[dRSeRSfRSgRShRSiRSjRSkRSlRSTRSmRSnRSoRSoRSpRSqRrsRrtRruRrvRrwRrxRryRrzRr{Rr|Rr|Rr}Rr~RrRRRRRRRRRRRRRRRRRRRRRRRRRRRRRUVRURURURRRRRRRRRRRRRRRRRRRRRRR`             !"#$%'buildbox-2.1.9.3-Fg406mJtjrG6Qa7DDVujhFBuildBox.Build BuildBox.TimeBuildBox.PrettyBuildBox.IO.DirectoryBuildBox.Data.ScheduleBuildBox.Data.LogBuildBox.Data.DividableBuildBox.Data.PhysicalBuildBox.Data.RangeBuildBox.Data.DetailBuildBox.Data.ComparisonBuildBox.Control.GangBuildBox.Build.BenchmarkBuildBox.Build.TestableBuildBox.Command.FileBuildBox.Command.SleepBuildBox.Command.SystemBuildBox.Command.DarcsBuildBox.Command.EnvironmentBuildBox.Command.MailBuildBox.Command.NetworkBuildBox.Control.Cron!BuildBox.Command.System.InternalsBuildBox.Build.BuildStateBuildBox.Build.BuildErrorBuildBox.Build.BaseBuildBox'exceptions-0.8.3-74UMKX8an841ULC0nHtYN7Control.Monad.CatchcatchreadLocalTimeOfDayAsUTC getStampyTimegetMidnightTodayLocalgetMidnightTodayUTCgetMidnightTomorrowLocalgetMidnightTomorrowUTCPrettypprpadRcpadRpadLcpadLblank pprEngInteger pprEngDouble $fPretty[] $fPretty[]0$fPrettyUTCTime$fPrettyInteger $fPrettyInt $fPrettyFloat $fPrettyDoc lsFilesInlsDirsIntraceFilesFromScheduleEvent eventName eventWheneventWhenModifiereventLastStartedeventLastEnded EventName WhenModifier Immediate WaitUntilWhenAlwaysNeverEveryAfterDailysecondminutehourdayearliestEventToStartAteventCouldStartAteventsOfSchedule makeSchedulelookupEventOfSchedulelookupCommandOfScheduleadjustEventOfSchedule$fReadNominalDiffTime $fReadWhen $fShowWhen$fEqWhen$fReadWhenModifier$fShowWhenModifier$fEqWhenModifier $fReadEvent $fShowEvent $fEqEventLineLogemptynulltoString fromString<||>>< firstLines lastLines Dividabledivide$fDividableFloat$fDividableIntegerBytesSeconds $fPrettyBytes $fNumBytes$fDividableBytes $fRealBytes$fPrettySeconds $fNumSeconds$fDividableSeconds $fRealSeconds $fReadSeconds $fShowSeconds $fOrdSeconds $fEqSeconds $fReadBytes $fShowBytes $fOrdBytes $fEqBytesRangerangeMinrangeAvgrangeMax makeRange flattenRange$fFunctorRange $fPrettyRange $fReadRange $fShowRangeSizedExeSizeUsedHeapMax HeapAllocTimed TotalWallTotalCpuTotalSys KernelWall KernelCpu KernelSysDetail DetailTimed DetailUsed DetailSized $fPrettySized $fPrettyUsed $fPrettyTimed $fEqTimed $fOrdTimed $fShowTimed $fReadTimed $fEnumTimed$fEqUsed $fOrdUsed $fShowUsed $fReadUsed $fEnumUsed $fEqSized $fOrdSized $fShowSized $fReadSized $fEnumSized $fEqDetail $fOrdDetail $fShowDetail $fReadDetail Comparison ComparisonNewcomparisonBaselinecomparisonRecentcomparisonSwing comparisonNewmakeComparison$fPrettyComparison$fReadComparison$fShowComparison GangState GangRunning GangPaused GangFlushing GangFinished GangKilledGang getGangStatejoinGang flushGang pauseGang resumeGangkillGangwaitForGangStateforkGangActions$fShowGangState $fEqGangState BuildStatebuildStateLogSystem buildStateSeqbuildStateScratchDirbuildStateDefault BuildError ErrorOtherErrorSystemCmdFailed ErrorIOErrorErrorCheckFailed ErrorNeeds buildErrorCmdbuildErrorCodebuildErrorStdoutbuildErrorStderrBuildrunBuild runBuildPrintrunBuildWithStaterunBuildPrintWithState successfullyneedsiowhenMoutoutLnoutBlankoutLineoutLINE BenchResultbenchResultNamebenchResultIterationbenchResultTimebenchResultValue Benchmark benchmarkNamebenchmarkSetupbenchmarkCommandbenchmarkCheck runBenchmarkiterateBenchmark timeBuildTestabletestcheck checkFalse outCheckOkoutCheckFalseOkthrow logSystemPropFile HasExecutableHasFileHasDir FileEmptyinDir inScratchDir clobberDir ensureDir withTempFileatomicWriteFileexe$fTestablePropFile$fShowPropFilesleepmsleepsystemsystemqssystemssystemqsesystem sesystemq systemTee systemTeeLog ssystemTee systemTeeIOsystemTeeLogIO DarcsPatchdarcsTimestamp darcsAuthor darcsComment EmailAddress DarcsPathchangeschangesN changesAfter$fShowDarcsPatchPlatformplatformHostNameplatformHostArchplatformHostProcessorplatformHostOSplatformHostRelease EnvironmentenvironmentPlatformenvironmentVersionsgetEnvironmentWithgetHostPlatform getHostName getHostArchgetHostProcessor getHostOSgetHostRelease getVersionGHC getVersionGCC$fPrettyPlatform$fPrettyEnvironment$fShowPlatform$fReadPlatform$fShowEnvironment$fReadEnvironmentMailerMailerSendmail MailerMSMTP mailerPathmailerExtraFlags mailerPortMailmailFrommailTo mailSubjectmailTime mailTimeZone mailMessageIdmailBodycreateMailWithCurrentTime renderMailsendMailWithMailer $fShowMail $fShowMailer PropNetwork HostReachable UrlGettable$fTestablePropNetwork$fShowPropNetworkcronLoop time-1.6.0.1Data.Time.LocalTime.LocalTime LocalTimeData.Time.Clock.UTCUTCTimeData.Time.Format formatTime FormatTimeformatCharacterData.Time.Format.Parse readsTimereadTime parseTime readPTime readSTimeparseTimeOrError parseTimeM ParseTime buildTimeutcToLocalZonedTime getZonedTimezonedTimeToUTCutcToZonedTimelocalTimeToUT1ut1ToLocalTimelocalTimeToUTCutcToLocalTimelocalDaylocalTimeOfDay ZonedTimezonedTimeToLocalTime zonedTimeZoneData.Time.LocalTime.TimeOfDaytimeOfDayToDayFractiondayFractionToTimeOfDaytimeOfDayToTimetimeToTimeOfDaylocalToUTCTimeOfDayutcToLocalTimeOfDaymakeTimeOfDayValidmiddaymidnight TimeOfDaytodHourtodMintodSecData.Time.Format.Localerfc822DateFormatiso8601DateFormatdefaultTimeLocale TimeLocalewDaysmonthsamPm dateTimeFmtdateFmttimeFmt time12FmtknownTimeZonesData.Time.LocalTime.TimeZonegetCurrentTimeZone getTimeZoneutctimeZoneOffsetStringtimeZoneOffsetString'hoursToTimeZoneminutesToTimeZoneTimeZonetimeZoneMinutestimeZoneSummerOnly timeZoneNameData.Time.Clock.UTCDiff diffUTCTime addUTCTimeData.Time.Clock.POSIXgetCurrentTimeutctDay utctDayTimeNominalDiffTimeData.Time.Calendar.GregorianaddGregorianYearsRollOveraddGregorianYearsClipaddGregorianMonthsRollOveraddGregorianMonthsClipgregorianMonthLength showGregorianfromGregorianValid fromGregorian toGregorianData.Time.Calendar.OrdinalDate isLeapYearData.Time.Calendar.DaysdiffDaysaddDaysDayModifiedJulianDaytoModifiedJulianDayData.Time.Calendar.PrivateNumericPadOptionData.Time.Clock.ScalediffTimeToPicosecondspicosecondsToDiffTimesecondsToDiffTime UniversalTime ModJulianDategetModJulianDateDiffTimepretty-1.1.3.3Text.PrettyPrint.HughesPJvcat fullRender renderStylerenderfsepfcatcatsep<+><>$+$$$ punctuatehangnesthsephcatbracesbracketsparens doubleQuotesquotesrationaldoublefloatintegerintrbracelbracerbracklbrackrparenlparenequalsspacecoloncommasemiisEmpty zeroWidthText sizedTextptexttextcharDoc#Text.PrettyPrint.Annotated.HughesPJstyle TextDetailsChrStrPStrStylemode lineLengthribbonsPerLineModePageMode ZigZagModeLeftMode OneLineModebaseGHC.Base. dropDotPathsStringgangThreadsAvailablegangLoop gangThreads gangStategangActionsRunninggangThreadsRunningstreamInNothing streamOuts hGetLineNLGHC.IO.Handle.TexthGetLine streamIn'uponMmkPSmkBigPS$fShowBuildError$fPrettyBuildError$fExceptionBuildErrorwhenthrowMGHC.IO.Exception ExitFailureExitCodedebugtrace slurpChan System.Exitdie exitSuccess exitFailureexitWith ExitSuccessdarcs splitPatchesURLHostName