Skip to content
This repository was archived by the owner on Jan 13, 2025. It is now read-only.
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .ci/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,7 @@ jobs:
inputs:
version: ${{ parameters.dotnet }}
performMultiLevelLookup: true
includePreviewVersions: true
condition: ne('${{ parameters.dotnet }}', '')
# custom init steps
- ${{ parameters.initSteps }}
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,4 @@ tmpnupkg/
*.user
artifacts/
.idea/
*.binlog
14 changes: 14 additions & 0 deletions Android/Guava/Directory.Build.props
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
<Project>
<PropertyGroup>
<!-- Uncomment if a $(PackageVersionSuffix) is ever needed -->
<!-- <PackageVersionSuffix>-net6preview04</PackageVersionSuffix> -->
<!-- <PackageVersionSuffix Condition=" '$(BUILD_BUILDID)' != '' ">$(PackageVersionSuffix).$(BUILD_BUILDID)</PackageVersionSuffix> -->
<GuavaNuGetVersion>28.2.0.1$(PackageVersionSuffix)</GuavaNuGetVersion>
<GuavaFailureAccessNuGetVersion>1.0.1.3$(PackageVersionSuffix)</GuavaFailureAccessNuGetVersion>
<GuavaListenableFutureNuGetVersion>1.0.0.3$(PackageVersionSuffix)</GuavaListenableFutureNuGetVersion>
</PropertyGroup>
<ItemGroup>
<_NuGetBuildFolders Include="build\;buildTransitive\" />
<_TfmNuGetBuildFolders Include="@(_NuGetBuildFolders->'%(Identity)monoandroid90\');@(_NuGetBuildFolders->'%(Identity)net6.0-android30.0\')" />
</ItemGroup>
</Project>
47 changes: 20 additions & 27 deletions Android/Guava/build.cake
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,6 @@ var GUAVA_VERSION = GUAVA_VERSION_BASE + "-android";
var GUAVA_FAILUREACCESS_VERSION = "1.0.1";
var GUAVA_LISTENABLEFUTURE_VERSION = "1.0";

var GUAVA_NUGET_VERSION = "28.2.0.0";
var GUAVA_FAILUREACCESS_NUGET_VERSION = "1.0.1.2";
var GUAVA_LISTENABLEFUTURE_NUGET_VERSION = "1.0.0.2";

var JSR305_VERSION = "3.0.2";
var CHECKER_COMPAT_QUAL_VERSION = "2.5.5";
var ERROR_PRONE_ANNOTATIONS_VERSION = "2.3.3";
Expand Down Expand Up @@ -99,50 +95,47 @@ Task ("externals")
if (zipFile != null)
zipFile.Close();
}

// Update .csproj nuget versions
XmlPoke("./source/Guava/Guava.csproj", "/Project/PropertyGroup/PackageVersion", GUAVA_NUGET_VERSION);
XmlPoke("./source/Guava.FailureAccess/Guava.FailureAccess.csproj", "/Project/PropertyGroup/PackageVersion", GUAVA_FAILUREACCESS_NUGET_VERSION);
XmlPoke("./source/Guava.ListenableFuture/Guava.ListenableFuture.csproj", "/Project/PropertyGroup/PackageVersion", GUAVA_LISTENABLEFUTURE_NUGET_VERSION);
});


Task("libs")
.IsDependentOn("externals")
.Does(() =>
{
MSBuild("./Guava.sln", c => {
c.Configuration = "Release";
c.Restore = true;
c.MaxCpuCount = 0;
c.Properties.Add("DesignTimeBuild", new [] { "false" });
});
DotNetCoreRestore ("./Guava.sln");

DotNetCoreMSBuild ("./Guava.sln",
new DotNetCoreMSBuildSettings()
.SetConfiguration("Release")
);
});

Task("nuget")
.IsDependentOn("libs")
.Does(() =>
{
MSBuild ("./Guava.sln", c => {
c.Configuration = "Release";
c.MaxCpuCount = 0;
c.Targets.Clear();
c.Targets.Add("Pack");
c.Properties.Add("PackageOutputPath", new [] { MakeAbsolute(new FilePath("./output")).FullPath });
c.Properties.Add("PackageRequireLicenseAcceptance", new [] { "true" });
c.Properties.Add("DesignTimeBuild", new [] { "false" });
c.Properties.Add("NoBuild", new [] { "true" });
});
DotNetCoreMSBuild ("./Guava.sln",
new DotNetCoreMSBuildSettings()
.WithTarget("Pack")
.SetConfiguration("Release")
.WithProperty ("PackageOutputPath", MakeAbsolute(new FilePath("./output")).FullPath)
.WithProperty ("PackageRequireLicenseAcceptance", "true")
.WithProperty ("NoBuild", "true")
);
});

Task("samples")
.IsDependentOn("nuget");
.IsDependentOn("nuget")
.Does (() =>
{
MSBuild("./samples/GuavaSample/GuavaSample.csproj", c => c.Restore = true);
});

Task ("clean")
.Does (() =>
{
if (DirectoryExists ("./externals/"))
DeleteDirectory ("./externals", true);
DeleteDirectory ("./externals", new DeleteDirectorySettings { Recursive = true });
});

Task ("ci")
Expand Down
25 changes: 25 additions & 0 deletions Android/Guava/samples/GuavaSample/Future.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
using Google.Common.Util.Concurrent;
using Java.Lang;
using Java.Util.Concurrent;

namespace GuavaSample
{
// Just ensure this compiles
public class Future : Java.Lang.Object, IListenableFuture
Comment on lines +7 to +8
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This sample isn't really that helpful, basically just an "integration test" checking a type exists.

When I look at GuavaSample.dll it has the same .jar files embedded as before:

image

{
public bool IsCancelled { get; set; }

public bool IsDone { get; set; }

public void AddListener(IRunnable p0, IExecutor p1)
{

}

public bool Cancel(bool mayInterruptIfRunning) => true;

public Object Get() => null;

public Object Get(long timeout, TimeUnit unit) => null;
}
}
57 changes: 57 additions & 0 deletions Android/Guava/samples/GuavaSample/GuavaSample.csproj
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
<Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
<ProductVersion>8.0.30703</ProductVersion>
<SchemaVersion>2.0</SchemaVersion>
<ProjectGuid>{FF3EDEBE-27B3-42E5-A713-9EA81CB5397A}</ProjectGuid>
<ProjectTypeGuids>{EFBA0AD7-5A72-4C68-AF49-83D382785DCF};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}</ProjectTypeGuids>
<TemplateGuid>{122416d6-6b49-4ee2-a1e8-b825f31c79fe}</TemplateGuid>
<OutputType>Library</OutputType>
<AppDesignerFolder>Properties</AppDesignerFolder>
<RootNamespace>GuavaSample</RootNamespace>
<AssemblyName>GuavaSample</AssemblyName>
<FileAlignment>512</FileAlignment>
<Deterministic>True</Deterministic>
<TargetFrameworkVersion>v11.0</TargetFrameworkVersion>
<AndroidClassParser>class-parse</AndroidClassParser>
<IsPackable>false</IsPackable>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<DebugSymbols>True</DebugSymbols>
<DebugType>portable</DebugType>
<Optimize>False</Optimize>
<OutputPath>bin\Debug\</OutputPath>
<DefineConstants>DEBUG;TRACE</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
</PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
<DebugSymbols>True</DebugSymbols>
<DebugType>portable</DebugType>
<Optimize>True</Optimize>
<OutputPath>bin\Release\</OutputPath>
<DefineConstants>TRACE</DefineConstants>
<ErrorReport>prompt</ErrorReport>
<WarningLevel>4</WarningLevel>
</PropertyGroup>
<ItemGroup>
<Reference Include="System" />
<Reference Include="System.Xml" />
<Reference Include="System.Core" />
<Reference Include="Mono.Android" />
<Reference Include="System.Numerics" />
<Reference Include="System.Numerics.Vectors" />
</ItemGroup>
<ItemGroup>
<Compile Include="Future.cs" />
<Compile Include="Properties\AssemblyInfo.cs" />
</ItemGroup>
<ItemGroup>
<PackageReference Include="Xamarin.Google.Guava" Version="$(GuavaNuGetVersion)" />
<PackageReference Include="Xamarin.Google.Guava.ListenableFuture" Version="$(GuavaListenableFutureNuGetVersion)" />
<PackageReference Include="Xamarin.Google.Guava.FailureAccess" Version="$(GuavaFailureAccessNuGetVersion)" />
</ItemGroup>
<Import Project="$(MSBuildExtensionsPath)\Xamarin\Android\Xamarin.Android.Bindings.targets" />
</Project>
26 changes: 26 additions & 0 deletions Android/Guava/samples/GuavaSample/Properties/AssemblyInfo.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
using System.Reflection;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using Android.App;

// General Information about an assembly is controlled through the following
// set of attributes. Change these attribute values to modify the information
// associated with an assembly.
[assembly: AssemblyTitle("GuavaSample")]
[assembly: AssemblyDescription("")]
[assembly: AssemblyConfiguration("")]
[assembly: AssemblyCompany("")]
[assembly: AssemblyProduct("GuavaSample")]
[assembly: AssemblyCopyright("Copyright © 2018")]
[assembly: AssemblyTrademark("")]
[assembly: AssemblyCulture("")]
[assembly: ComVisible(false)]

// Version information for an assembly consists of the following four values:
//
// Major Version
// Minor Version
// Build Number
// Revision
[assembly: AssemblyVersion("1.0.0.0")]
[assembly: AssemblyFileVersion("1.0.0.0")]
6 changes: 6 additions & 0 deletions Android/Guava/samples/NuGet.config
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<add key="local-output" value="../output" />
</packageSources>
</configuration>
Original file line number Diff line number Diff line change
@@ -1,17 +1,9 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="MSBuild.Sdk.Extras/2.0.54">
<Project Sdk="Xamarin.Legacy.Sdk">
<PropertyGroup>
<TargetFramework>monoandroid90</TargetFramework>
<TargetFrameworks>net6.0-android30;monoandroid90</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<AssemblyName>Xamarin.Google.Guava.FailureAccess</AssemblyName>
<MonoAndroidResourcePrefix>Resources</MonoAndroidResourcePrefix>
<MonoAndroidAssetsPrefix>Assets</MonoAndroidAssetsPrefix>
<AndroidUseLatestPlatformSdk>False</AndroidUseLatestPlatformSdk>
<AndroidUseIntermediateDesignerFile>True</AndroidUseIntermediateDesignerFile>
<AndroidResgenFile>Resources\Resource.designer.cs</AndroidResgenFile>
<RootNamespace>Guava.FailureAccess</RootNamespace>
<AndroidClassParser>class-parse</AndroidClassParser>
<AndroidCodegenTarget>XAJavaInterop1</AndroidCodegenTarget>
<Java7DocPaths>..\..\externals\guava-failureaccess-javadocs\</Java7DocPaths>
</PropertyGroup>

Expand All @@ -32,20 +24,17 @@ Guava is a set of core libraries that includes new collection types (such as mul
<PackageProjectUrl>https://go.microsoft.com/fwlink/?linkid=865028</PackageProjectUrl>
<PackageLicenseUrl>https://go.microsoft.com/fwlink/?linkid=865030</PackageLicenseUrl>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<PackageVersion>1.0.1.2</PackageVersion>
<PackageVersion>$(GuavaFailureAccessNuGetVersion)</PackageVersion>
</PropertyGroup>

<ItemGroup>
<None Include="Guava.FailureAccess.targets" Pack="True" PackagePath="build\$(TargetFramework)\$(PackageId).targets" />
<None Include="Guava.FailureAccess.targets" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\$(PackageId).targets" />
<None Include="..\..\externals\guava-failureaccess.jar" Pack="True" PackagePath="build\$(TargetFramework)\guava-failureaccess.jar" />
<None Include="..\..\externals\guava-failureaccess.jar" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\guava-failureaccess.jar" />
<None Include="Guava.FailureAccess.targets" Pack="True" PackagePath="@(_TfmNuGetBuildFolders->'%(Identity)$(PackageId).targets')" />
<None Include="..\..\externals\guava-failureaccess.jar" Pack="True" PackagePath="jar" />
<None Include="..\..\External-Dependency-Info.txt" Pack="True" PackagePath="THIRD-PARTY-NOTICES.txt" />
</ItemGroup>

<ItemGroup>
<InputJar Include="..\..\externals\guava-failureaccess.jar" />
<TransformFile Include="Transforms.xml" />
</ItemGroup>

</Project>
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<AndroidJavaLibrary Include="$(MSBuildThisFileDirectory)*.jar" />
<AndroidJavaLibrary Include="$(MSBuildThisFileDirectory)..\..\jar\*.jar" />
</ItemGroup>
</Project>
Original file line number Diff line number Diff line change
@@ -1,17 +1,9 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="MSBuild.Sdk.Extras/2.0.54">
<Project Sdk="Xamarin.Legacy.Sdk">
<PropertyGroup>
<TargetFramework>monoandroid90</TargetFramework>
<TargetFrameworks>net6.0-android30;monoandroid90</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<AssemblyName>Xamarin.Google.Guava.ListenableFuture</AssemblyName>
<MonoAndroidResourcePrefix>Resources</MonoAndroidResourcePrefix>
<MonoAndroidAssetsPrefix>Assets</MonoAndroidAssetsPrefix>
<AndroidUseLatestPlatformSdk>False</AndroidUseLatestPlatformSdk>
<AndroidUseIntermediateDesignerFile>True</AndroidUseIntermediateDesignerFile>
<AndroidResgenFile>Resources\Resource.designer.cs</AndroidResgenFile>
<RootNamespace>Guava.ListenableFuture</RootNamespace>
<AndroidClassParser>class-parse</AndroidClassParser>
<AndroidCodegenTarget>XAJavaInterop1</AndroidCodegenTarget>
<Java7DocPaths>..\..\externals\guava-listenablefuture-javadocs\</Java7DocPaths>
</PropertyGroup>

Expand All @@ -32,20 +24,17 @@ Guava is a set of core libraries that includes new collection types (such as mul
<PackageProjectUrl>https://go.microsoft.com/fwlink/?linkid=865028</PackageProjectUrl>
<PackageLicenseUrl>https://go.microsoft.com/fwlink/?linkid=865030</PackageLicenseUrl>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<PackageVersion>1.0.0.2</PackageVersion>
<PackageVersion>$(GuavaListenableFutureNuGetVersion)</PackageVersion>
</PropertyGroup>

<ItemGroup>
<None Include="Guava.ListenableFuture.targets" Pack="True" PackagePath="build\$(TargetFramework)\$(PackageId).targets" />
<None Include="Guava.ListenableFuture.targets" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\$(PackageId).targets" />
<None Include="..\..\externals\guava-listenablefuture.jar" Pack="True" PackagePath="build\$(TargetFramework)\guava-listenablefuture.jar" />
<None Include="..\..\externals\guava-listenablefuture.jar" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\guava-listenablefuture.jar" />
<None Include="Guava.ListenableFuture.targets" Pack="True" PackagePath="@(_TfmNuGetBuildFolders->'%(Identity)$(PackageId).targets')" />
<None Include="..\..\externals\guava-listenablefuture.jar" Pack="True" PackagePath="jar" />
<None Include="..\..\External-Dependency-Info.txt" Pack="True" PackagePath="THIRD-PARTY-NOTICES.txt" />
</ItemGroup>

<ItemGroup>
<InputJar Include="..\..\externals\guava-listenablefuture.jar" />
<TransformFile Include="Transforms.xml" />
</ItemGroup>

</Project>
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<AndroidJavaLibrary Include="$(MSBuildThisFileDirectory)*.jar" />
<AndroidJavaLibrary Include="$(MSBuildThisFileDirectory)..\..\jar\*.jar" />
</ItemGroup>
</Project>
21 changes: 5 additions & 16 deletions Android/Guava/source/Guava/Guava.csproj
Original file line number Diff line number Diff line change
@@ -1,17 +1,9 @@
<?xml version="1.0" encoding="utf-8"?>
<Project Sdk="MSBuild.Sdk.Extras/2.0.54">
<Project Sdk="Xamarin.Legacy.Sdk">
<PropertyGroup>
<TargetFramework>monoandroid90</TargetFramework>
<TargetFrameworks>net6.0-android30;monoandroid90</TargetFrameworks>
<IsBindingProject>true</IsBindingProject>
<AssemblyName>Xamarin.Google.Guava</AssemblyName>
<MonoAndroidResourcePrefix>Resources</MonoAndroidResourcePrefix>
<MonoAndroidAssetsPrefix>Assets</MonoAndroidAssetsPrefix>
<AndroidUseLatestPlatformSdk>False</AndroidUseLatestPlatformSdk>
<AndroidUseIntermediateDesignerFile>True</AndroidUseIntermediateDesignerFile>
<AndroidResgenFile>Resources\Resource.designer.cs</AndroidResgenFile>
<RootNamespace>Guava</RootNamespace>
<AndroidClassParser>class-parse</AndroidClassParser>
<AndroidCodegenTarget>XAJavaInterop1</AndroidCodegenTarget>
<Java7DocPaths>..\..\externals\guava-javadocs\</Java7DocPaths>
</PropertyGroup>

Expand All @@ -32,14 +24,12 @@ Guava is a set of core libraries that includes new collection types (such as mul
<PackageProjectUrl>https://go.microsoft.com/fwlink/?linkid=865028</PackageProjectUrl>
<PackageLicenseUrl>https://go.microsoft.com/fwlink/?linkid=865030</PackageLicenseUrl>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<PackageVersion>28.2.0.0</PackageVersion>
<PackageVersion>$(GuavaNuGetVersion)</PackageVersion>
</PropertyGroup>

<ItemGroup>
<None Include="Guava.targets" Pack="True" PackagePath="build\$(TargetFramework)\$(PackageId).targets" />
<None Include="Guava.targets" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\$(PackageId).targets" />
<None Include="..\..\externals\guava.jar" Pack="True" PackagePath="build\$(TargetFramework)\guava.jar" />
<None Include="..\..\externals\guava.jar" Pack="True" PackagePath="buildTransitive\$(TargetFramework)\guava.jar" />
<None Include="Guava.targets" Pack="True" PackagePath="@(_TfmNuGetBuildFolders->'%(Identity)$(PackageId).targets')" />
<None Include="..\..\externals\guava.jar" Pack="True" PackagePath="jar" />
<None Include="..\..\External-Dependency-Info.txt" Pack="True" PackagePath="THIRD-PARTY-NOTICES.txt" />
</ItemGroup>

Expand All @@ -50,7 +40,6 @@ Guava is a set of core libraries that includes new collection types (such as mul

<ItemGroup>
<InputJar Include="..\..\externals\guava.jar" />
<TransformFile Include="Transforms.xml" />
</ItemGroup>

</Project>
2 changes: 1 addition & 1 deletion Android/Guava/source/Guava/Guava.targets
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<EmbeddedReferenceJar Include="$(MSBuildThisFileDirectory)*.jar" />
<EmbeddedReferenceJar Include="$(MSBuildThisFileDirectory)..\..\jar\*.jar" />
</ItemGroup>
</Project>
Loading