Files
ortools-clone/ortools/constraint_solver/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

146 lines
4.1 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.ConstraintSolver {
using System;
using System.Collections.Generic;
// int[] and long[] helper class.
public static class IntArrayHelper {
public static IntExpr Element(this int[] array, IntExpr index) {
return index.solver().MakeElement(array, index.Var());
}
public static IntExpr Element(this long[] array, IntExpr index) {
return index.solver().MakeElement(array, index.Var());
}
}
public partial class CpInt64Vector: IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IList<long>
#endif
{
// cast from C# long array
public static implicit operator CpInt64Vector(long[] inVal) {
var outVal= new CpInt64Vector();
foreach (long element in inVal) {
outVal.Add(element);
}
return outVal;
}
// cast to C# long array
public static implicit operator long[](CpInt64Vector inVal) {
var outVal= new long[inVal.Count];
inVal.CopyTo(outVal);
return outVal;
}
}
public partial class CpIntVector: IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IList<int>
#endif
{
// cast from C# int array
public static implicit operator CpIntVector(int[] inVal) {
var outVal= new CpIntVector();
foreach (int element in inVal) {
outVal.Add(element);
}
return outVal;
}
// cast to C# int array
public static implicit operator int[](CpIntVector inVal) {
var outVal= new int[inVal.Count];
inVal.CopyTo(outVal);
return outVal;
}
}
public partial class CpIntVectorVector : IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IEnumerable<CpIntVector>
#endif
{
// cast from C# int matrix
public static implicit operator CpIntVectorVector(int[,] inVal) {
int x_size = inVal.GetLength(0);
int y_size = inVal.GetLength(1);
CpIntVectorVector outVal = new CpIntVectorVector();
for (int i = 0; i < x_size; ++i)
{
outVal.Add(new CpIntVector());
for (int j = 0; j < y_size; ++j)
{
outVal[i].Add(inVal[i, j]);
}
}
return outVal;
}
// cast to C# int matrix
public static implicit operator int[,](CpIntVectorVector inVal) {
int x_size = inVal.Count;
int y_size = inVal.Count == 0 ? 0 : inVal[0].Count;
var outVal= new int[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;
}
}
public partial class CpInt64VectorVector : IDisposable, System.Collections.IEnumerable
#if !SWIG_DOTNET_1
, System.Collections.Generic.IEnumerable<CpInt64Vector>
#endif
{
// cast from C# long matrix
public static implicit operator CpInt64VectorVector(long[,] inVal) {
int x_size = inVal.GetLength(0);
int y_size = inVal.GetLength(1);
CpInt64VectorVector outVal = new CpInt64VectorVector();
for (int i = 0; i < x_size; ++i)
{
outVal.Add(new CpInt64Vector());
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[,](CpInt64VectorVector 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.ConstraintSolver