Files
ortools-clone/ortools/algorithms/csharp/IntArrayHelper.cs
Corentin Le Molgat 62cbe9a228 dotnet: Full Rework
- Create native project runtime.{rid}.Google.OrTools
  - follow the microsoft convention e.g.:
  https://www.nuget.org/packages/Microsoft.NETCore.App/
  https://www.nuget.org/packages/runtime.linux-x64.Microsoft.NETCore.App/
- Target `make_dotnet` targets local nupkg instead of dll.
- Use 4096 RSA key for or-tools.snk
- Clean nuget cache in `clean_dotnet` recipe

Refactor:
- Move cs files to ortools/*/csharp
- Move dotnet project to ortools/dotnet/Google.OrTools
- Move example generation to temp_dotnet
  - Avoid to mess the `BIN_DIR`
- Rework Google.OrTools.FSharp

Cleanup:
- Remove deps to netfx.props since we only support:
  netstandard2.0 TFM and netcoreapp2.1 Runtime TFM
- Remove OrTools.nuspec.in
  -> use newly added properties to .csproj format
- Remove of ortools/dotnet/OrTools project
  - replaced by ortools/dotnet/Google.OrTools
- Remove provided protobuf.dll.
  - Automatically retrieved from nuget.org

Misc:
- Add **/*.csproj to gitignore
- Add **/runtime.json to gitignore

- dotnet: Makefile windows fix
  - make.exe doesn't support `else ifeq`
2018-08-30 11:58:47 +02:00

77 lines
2.2 KiB
C#

// Copyright 2010-2017 Google
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
namespace Google.OrTools.Algorithms {
using System;
using System.Collections.Generic;
public partial class KInt64Vector: IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IList<long>
#endif
{
// cast from C# long array
public static implicit operator KInt64Vector(long[] inVal) {
var outVal= new KInt64Vector();
foreach (long element in inVal) {
outVal.Add(element);
}
return outVal;
}
// cast to C# long array
public static implicit operator long[](KInt64Vector inVal) {
var outVal= new long[inVal.Count];
inVal.CopyTo(outVal);
return outVal;
}
}
public partial class KInt64VectorVector : IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IEnumerable<KInt64Vector>
#endif
{
// cast from C# long matrix
public static implicit operator KInt64VectorVector(long[,] inVal) {
int x_size = inVal.GetLength(0);
int y_size = inVal.GetLength(1);
KInt64VectorVector outVal = new KInt64VectorVector();
for (int i = 0; i < x_size; ++i)
{
outVal.Add(new KInt64Vector());
for (int j = 0; j < y_size; ++j)
{
outVal[i].Add(inVal[i, j]);
}
}
return outVal;
}
// cast to C# long matrix
public static implicit operator long[,](KInt64VectorVector inVal) {
int x_size = inVal.Count;
int y_size = inVal.Count == 0 ? 0 : inVal[0].Count;
var outVal= new long[x_size, y_size];
for (int i = 0; i < x_size; ++i)
{
for (int j = 0; j < y_size; ++j)
{
outVal[i, j] = inVal[i][j];
}
}
return outVal;
}
}
} // namespace Google.OrTools.Algorithms