From ffcd455713ead932982837abbbc01aa6681b9f9f Mon Sep 17 00:00:00 2001 From: Thomas Goyne Date: Fri, 9 Nov 2012 13:33:03 -0800 Subject: [PATCH] Add fribidi project --- aegisub/build/Aegisub/Aegisub.vcxproj | 2 +- aegisub/build/BuildTasks/BuildTasks.fs | 86 +++++++++++-- aegisub/build/BuildTasks/BuildTasks.fsproj | 114 +++++++++--------- aegisub/build/fribidi/fribidi.vcxproj | 92 ++++++++++++++ aegisub/build/fribidi/fribidi.vcxproj.filters | 2 + 5 files changed, 229 insertions(+), 67 deletions(-) create mode 100644 aegisub/build/fribidi/fribidi.vcxproj create mode 100644 aegisub/build/fribidi/fribidi.vcxproj.filters diff --git a/aegisub/build/Aegisub/Aegisub.vcxproj b/aegisub/build/Aegisub/Aegisub.vcxproj index 95fbe4280..2759a3f79 100644 --- a/aegisub/build/Aegisub/Aegisub.vcxproj +++ b/aegisub/build/Aegisub/Aegisub.vcxproj @@ -47,7 +47,7 @@ - + diff --git a/aegisub/build/BuildTasks/BuildTasks.fs b/aegisub/build/BuildTasks/BuildTasks.fs index 550900866..e3a5e74a4 100644 --- a/aegisub/build/BuildTasks/BuildTasks.fs +++ b/aegisub/build/BuildTasks/BuildTasks.fs @@ -22,8 +22,8 @@ open Microsoft.Build.Evaluation open Microsoft.Build.Framework open Microsoft.Build.Utilities -exception ShellException of string - +/// Search the executable path for the directory containing the given file and +/// return it or empty string if not found let searchPath file = Environment.GetEnvironmentVariable("path").Split ';' |> Seq.map (fun p -> IO.Path.Combine(p, file)) @@ -31,6 +31,8 @@ let searchPath file = |> Seq.append [""] |> Seq.nth 1 +/// Read all of the defined properties from the calling project file and stuff +/// them in a Map let propertyMap (be : IBuildEngine) = use reader = Xml.XmlReader.Create(be.ProjectFileOfTaskNode) let project = new Project(reader) @@ -41,44 +43,106 @@ let propertyMap (be : IBuildEngine) = |> Seq.map (fun x -> (x.Name, x.EvaluatedValue)) |> Map.ofSeq +/// Convert a windows path possibly relative to the Aegisub project file to an +/// absolute msys path +let mungePath projectDir path = + let matchre pat str = + let m = System.Text.RegularExpressions.Regex.Match(str, pat) + if m.Success + then List.tail [ for g in m.Groups -> g.Value ] + else [] + match IO.Path.Combine(projectDir, path) |> matchre "([A-Za-z]):\\\\(.*)" with + | drive :: path :: [] -> sprintf "/%s/%s" drive (path.Replace('\\', '/')) + | _ -> failwith <| sprintf "Bad path: '%s' '%s'" projectDir path + type ShellWrapper(props : Map) = + let setPath msysRoot = + Environment.SetEnvironmentVariable("path", msysRoot + "\\bin;" + props.["NativeExecutablePath"]) + Environment.SetEnvironmentVariable("CC", "cl") + Environment.SetEnvironmentVariable("INCLUDE", props.["IncludePath"]) + Environment.SetEnvironmentVariable("LIB", props.["LibraryPath"]) + let sh = match props.TryFind "MsysBasePath" with | None | Some "" -> searchPath "sh.exe" - | Some path -> sprintf "%s\\bin\\sh.exe" path + | Some path -> setPath path; sprintf "%s\\bin\\sh.exe" path let cwd = function | null | "" -> props.["AegisubSourceBase"] - | x -> x + | x -> if not <| IO.Directory.Exists x then ignore <| IO.Directory.CreateDirectory(x) + x - member this.call scriptName workingDir = + member this.call args workingDir = if not <| IO.File.Exists sh then - raise <| ShellException "sh.exe not found. Make sure the MSYS root is set to a correct location." + failwith "sh.exe not found. Make sure the MSYS root is set to a correct location." let info = new ProcessStartInfo(FileName = sh - , Arguments = scriptName + , Arguments = args , WorkingDirectory = cwd workingDir , RedirectStandardOutput = true , UseShellExecute = false) use p = new Process(StartInfo = info) ignore(p.Start()) + let output = p.StandardOutput.ReadToEnd() p.WaitForExit() if p.ExitCode <> 0 then - raise <| ShellException(p.StandardOutput.ReadToEnd()) + failwith output + + member this.callScript scriptName args workingDir = + this.call (sprintf "%s %s" (mungePath props.["ProjectDir"] scriptName) args) workingDir type ExecShellScript() = inherit Task() member val WorkingDirectory = "" with get, set member val Command = "" with get, set + member val Script = "" with get, set + member val Arguments = "" with get, set override this.Execute() = try let sw = ShellWrapper (propertyMap this.BuildEngine) - this.Log.LogMessage("Calling '{0}'", this.Command); - sw.call this.Command this.WorkingDirectory + if this.Script.Length > 0 + then this.Log.LogMessage("Calling '{0}' {1}", this.Script, this.Arguments); + sw.callScript this.Script this.Arguments this.WorkingDirectory + else this.Log.LogMessage("Calling '{0}' {1}", this.Command, this.Arguments); + sw.call (sprintf "-c '%s %s'" this.Command this.Arguments) this.WorkingDirectory true - with ShellException(e) -> + with Failure(e) -> this.Log.LogError(e) false + +type MsysPath() = + inherit Task() + + member val ProjectDir = "" with get, set + member val Path = "" with get, set + + [] + member val Result = "" with get, set + + override this.Execute() = + try + this.Result <- mungePath this.ProjectDir this.Path + true + with Failure(e) -> + this.Log.LogError(e) + false + +type UpdateFile() = + inherit Task() + + member val File = "" with get, set + member val Find = "" with get, set + member val Replacement = "" with get, set + + override this.Execute() = + try + this.Log.LogMessage("Replacing '{0}' with '{1}' in '{2}'", this.Find, this.Replacement, this.File) + let text = IO.File.ReadAllText(this.File).Replace(this.Find, this.Replacement) + IO.File.WriteAllText(this.File, text) + true + with e -> + this.Log.LogErrorFromException e + false diff --git a/aegisub/build/BuildTasks/BuildTasks.fsproj b/aegisub/build/BuildTasks/BuildTasks.fsproj index 362a83980..36561c33f 100644 --- a/aegisub/build/BuildTasks/BuildTasks.fsproj +++ b/aegisub/build/BuildTasks/BuildTasks.fsproj @@ -1,55 +1,59 @@ - - - - - Debug - AnyCPU - 2.0 - 15c79e75-f5f6-451d-b870-94ed02af257e - Library - BuildTakss - BuildTasks - v4.5 - BuildTasks - BuildTasks - - - - $(AegisubBinaryDir) - $(AegisubObjectDir) - - - true - full - false - false - DEBUG;TRACE - 3 - - - pdbonly - true - true - TRACE - 3 - - - - - - - - - - - - - - - - - - 11 - - - + + + + + Debug + AnyCPU + 2.0 + 15c79e75-f5f6-451d-b870-94ed02af257e + Library + BuildTakss + BuildTasks + v4.5 + BuildTasks + BuildTasks + + + + $(AegisubBinaryDir) + $(AegisubObjectDir) + + + true + full + false + false + DEBUG;TRACE + 3 + Program + C:\Windows\Microsoft.NET\Framework\v4.0.30319\MSBuild.exe + Z:\src\temp\aegisub\aegisub + /p:BuildProjectReferences=false build\fribidi\fribidi.vcxproj + + + pdbonly + true + true + TRACE + 3 + + + + + + + + + + + + + + + + + + 11 + + + \ No newline at end of file diff --git a/aegisub/build/fribidi/fribidi.vcxproj b/aegisub/build/fribidi/fribidi.vcxproj new file mode 100644 index 000000000..f4d5ce8df --- /dev/null +++ b/aegisub/build/fribidi/fribidi.vcxproj @@ -0,0 +1,92 @@ + + + + + + Debug + Win32 + + + Debug + x64 + + + Release + Win32 + + + Release + x64 + + + + + {FB8E8D19-A4D6-4181-943C-282075F49B41} + MakeFileProj + Makefile + + + + + + + + + + + + + --enable-debug + --disable-debug + --enable-static --disable-shared --disable-dependency-tracking --without-glib $(CfgEnableDebug) + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/aegisub/build/fribidi/fribidi.vcxproj.filters b/aegisub/build/fribidi/fribidi.vcxproj.filters new file mode 100644 index 000000000..679080f60 --- /dev/null +++ b/aegisub/build/fribidi/fribidi.vcxproj.filters @@ -0,0 +1,2 @@ + + \ No newline at end of file