Skip to content

Commit

Permalink
Merge branch 'feature/NET_4.0_Support' into develop
Browse files Browse the repository at this point in the history
  • Loading branch information
Marco Spatz committed Nov 19, 2014
2 parents 7879357 + 865ec38 commit 2999803
Show file tree
Hide file tree
Showing 6 changed files with 47 additions and 54 deletions.
10 changes: 4 additions & 6 deletions GenericStl/AsciiStlReader.cs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ public AsciiStlReader(Func<TVertex, TVertex, TVertex, TNormal, TTriangle> create

public AsciiStlReader(IDataStructureCreator<TTriangle, TVertex, TNormal> structureCreator)
: base(structureCreator)
{
{
}

public IEnumerable<TTriangle> Read(IEnumerable<string> fileContent)
Expand Down Expand Up @@ -55,12 +55,10 @@ public override IEnumerable<TTriangle> ReadFromStream(Stream s)

private static IEnumerable<string> ReadLines(Stream s)
{
using (var r = new StreamReader(s, Encoding.UTF8, true, DefaultBufferSize, true))
var r = new StreamReader(s, Encoding.UTF8, true, DefaultBufferSize); // do not dispose this reader as it would dispose the stream
while (!r.EndOfStream)
{
while (!r.EndOfStream)
{
yield return r.ReadLine();
}
yield return r.ReadLine();
}
}

Expand Down
10 changes: 4 additions & 6 deletions GenericStl/AsciiStlWriter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,14 @@ namespace GenericStl
[SuppressMessage("Microsoft.Design", "CA1005:AvoidExcessiveParametersOnGenericTypes")]
public class AsciiStlWriter<TTriangle, TVertex, TNormal> : StlWriterBase<TTriangle, TVertex, TNormal>
{
public AsciiStlWriter(Func<TTriangle, Tuple<TVertex, TVertex, TVertex, TNormal>> extractTriangle, Func<TVertex, Tuple<float, float, float>> extractVertex, Func<TNormal, Tuple<float, float, float>> extractNormal)
public AsciiStlWriter(Func<TTriangle, Tuple<TVertex, TVertex, TVertex, TNormal>> extractTriangle, Func<TVertex, Tuple<float, float, float>> extractVertex, Func<TNormal, Tuple<float, float, float>> extractNormal)
: base(extractTriangle, extractVertex, extractNormal)
{
}

public AsciiStlWriter(IDataStructureExtractor<TTriangle, TVertex, TNormal> extractor)
: base(extractor)
{

}

public override void WriteToFile(string fileName, IEnumerable<TTriangle> triangles)
Expand Down Expand Up @@ -47,10 +46,9 @@ public override void WriteToStream(Stream s, IEnumerable<TTriangle> triangles)
throw new ArgumentNullException("triangles");
}

using (var w = new StreamWriter(s, new UTF8Encoding(false, true), 1024, true))
{
WriteTo(w, triangles);
}
var w = new StreamWriter(s, new UTF8Encoding(false, true), 1024); // do not dispose this reader as it would dispose the stream
WriteTo(w, triangles);
w.Flush();
}

public string Write(IEnumerable<TTriangle> triangles)
Expand Down
26 changes: 12 additions & 14 deletions GenericStl/BinaryStlReader.cs
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,14 @@ namespace GenericStl
{
public class BinaryStlReader<TTriangle, TVertex, TNormal> : StlReaderBase<TTriangle, TVertex, TNormal>
{
public BinaryStlReader(Func<TVertex, TVertex, TVertex, TNormal, TTriangle> createTriangle, Func<float, float, float, TVertex> createVertex, Func<float, float, float, TNormal> createNormal)
public BinaryStlReader(Func<TVertex, TVertex, TVertex, TNormal, TTriangle> createTriangle, Func<float, float, float, TVertex> createVertex, Func<float, float, float, TNormal> createNormal)
: base(createTriangle, createVertex, createNormal)
{

}

public BinaryStlReader(IDataStructureCreator<TTriangle, TVertex, TNormal> structureCreator)
: base(structureCreator)
{
{
}

public override IEnumerable<TTriangle> ReadFromFile(string fileName)
Expand All @@ -34,19 +33,18 @@ public override IEnumerable<TTriangle> ReadFromStream(Stream s)
throw new ArgumentNullException("s");
}

using (var reader = new BinaryReader(s, Encoding.UTF8, true))
{
reader.ReadBytes(80); //header
var reader = new BinaryReader(s, Encoding.UTF8); // do not dispose this reader as it would dispose the stream

var numTriangles = reader.ReadInt32();
reader.ReadBytes(80); //header

for (var i = 0; i < numTriangles; ++i)
{
yield return ReadTriangle(reader);
}
var numTriangles = reader.ReadInt32();

Debug.Assert(s.Position == s.Length);
for (var i = 0; i < numTriangles; ++i)
{
yield return ReadTriangle(reader);
}

Debug.Assert(s.Position == s.Length);
}


Expand Down Expand Up @@ -78,7 +76,7 @@ public IEnumerable<TTriangle> Read(byte[] data)
using (var s = new MemoryStream(data, false))
{
foreach (var triangle in ReadFromStream(s)) yield return triangle;
}
}
}
}
}
}
27 changes: 13 additions & 14 deletions GenericStl/BinaryStlWriter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -62,23 +62,22 @@ public void WriteToStream(Stream s, IEnumerable<TTriangle> triangles, byte[] hea

var hdr = PrepareHeader(header);

using (var w = new BinaryWriter(s, new UTF8Encoding(false, true), true))
{
WriteHeader(w, hdr);
WriteLength(w, 0);

var length = 0;
var w = new BinaryWriter(s, new UTF8Encoding(false, true)); // do not dispose this reader as it would dispose the stream
WriteHeader(w, hdr);
WriteLength(w, 0);

foreach (var triangle in triangles)
{
length++;
var length = 0;

WriteTriangle(w, triangle);
}
foreach (var triangle in triangles)
{
length++;

s.Seek(HeaderLengthInByte, SeekOrigin.Begin);
WriteLength(w, length);
WriteTriangle(w, triangle);
}

s.Seek(HeaderLengthInByte, SeekOrigin.Begin);
WriteLength(w, length);
w.Flush();
}

private static byte[] PrepareHeader(byte[] header)
Expand All @@ -97,7 +96,7 @@ private static byte[] PrepareHeader(byte[] header)

if (header.Length < HeaderLengthInByte)
{
Array.Copy(header, newHdr, header.Length);
Array.Copy(header, newHdr, header.Length);
}
else if (header.Length > HeaderLengthInByte)
{
Expand Down
3 changes: 2 additions & 1 deletion GenericStl/GenericStl.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -9,11 +9,12 @@
<AppDesignerFolder>Properties</AppDesignerFolder>
<RootNamespace>GenericStl</RootNamespace>
<AssemblyName>GenericStl</AssemblyName>
<TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
<TargetFrameworkVersion>v4.0</TargetFrameworkVersion>
<FileAlignment>512</FileAlignment>
<SolutionDir Condition="$(SolutionDir) == '' Or $(SolutionDir) == '*Undefined*'">..\</SolutionDir>
<RestorePackages>true</RestorePackages>
<BuildPackage>true</BuildPackage>
<TargetFrameworkProfile />
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<DebugSymbols>true</DebugSymbols>
Expand Down
25 changes: 12 additions & 13 deletions GenericStl/StlFile.cs
Original file line number Diff line number Diff line change
Expand Up @@ -23,24 +23,23 @@ public static bool IsBinary(Stream stream)
{
try
{
using(var r = new BinaryReader(stream, Encoding.UTF8, true))
{
var firstChars = new string(r.ReadChars(5));
var r = new BinaryReader(stream, Encoding.UTF8); // do not dispose this reader as it would dispose the stream

if (!string.Equals(firstChars, "solid", StringComparison.OrdinalIgnoreCase))
{
return true;
}
var firstChars = new string(r.ReadChars(5));

var numberOfCharsToReadAtEnd = "endsolid".Length + 300;
numberOfCharsToReadAtEnd = numberOfCharsToReadAtEnd > stream.Length ? (int)stream.Length : numberOfCharsToReadAtEnd;
if (!string.Equals(firstChars, "solid", StringComparison.OrdinalIgnoreCase))
{
return true;
}

stream.Seek(-numberOfCharsToReadAtEnd , SeekOrigin.End);
var numberOfCharsToReadAtEnd = "endsolid".Length + 300;
numberOfCharsToReadAtEnd = numberOfCharsToReadAtEnd > stream.Length ? (int) stream.Length : numberOfCharsToReadAtEnd;

var lastChars = new string(r.ReadChars(numberOfCharsToReadAtEnd));
stream.Seek(-numberOfCharsToReadAtEnd, SeekOrigin.End);

return !lastChars.Contains("endsolid");
}
var lastChars = new string(r.ReadChars(numberOfCharsToReadAtEnd));

return !lastChars.Contains("endsolid");
}
finally
{
Expand Down

0 comments on commit 2999803

Please sign in to comment.