Skip to content
Open
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
20 changes: 20 additions & 0 deletions .bazelci/presubmit.yml
Original file line number Diff line number Diff line change
Expand Up @@ -175,3 +175,23 @@ tasks:
<<: *rules_flags
build_targets:
- "//java/com/basicapp:basic_app"
ubuntu2004_bundle:
name: "Bundle app ubuntu"
platform: ubuntu2004
bazel: ${{ bazel }}
working_directory: examples/bundle
build_flags:
<<: *rules_flags
build_targets:
- "//app:assets"
ubuntu2004_bundle_bzlmod:
name: "Bundle app ubuntu bzlmod"
platform: ubuntu2004
bazel: ${{ bazel }}
working_directory: examples/bundle
build_flags:
<<: *rules_flags
? "--enable_bzlmod"
? "--enable_workspace=false"
build_targets:
- "//app:assets"
10 changes: 10 additions & 0 deletions examples/bundle/.bazelrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
# Flags needed while the Android rules are being migrated to Starlark.
common --experimental_google_legacy_api
common --experimental_enable_android_migration_apis
common --android_sdk=@androidsdk//:sdk
common:core_library_desugaring --desugar_java8_libs

# Flags to enable mobile-install v3
mobile-install --mode=skylark --mobile_install_aspect=@rules_android//mobile_install:mi.bzl --mobile_install_supported_rules=android_binary
# Required to invoke the Studio deployer jar
mobile-install --tool_java_runtime_version=17
1 change: 1 addition & 0 deletions examples/bundle/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
*.lock
1 change: 1 addition & 0 deletions examples/bundle/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Empty build file to satisfy gazelle for rules_go.
55 changes: 55 additions & 0 deletions examples/bundle/MODULE.bazel
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
module(
name = "bundle",
)

bazel_dep(name = "rules_java", version = "7.4.0")
bazel_dep(name = "bazel_skylib", version = "1.3.0")

bazel_dep(
name = "rules_android",
version = "0.5.1",
)

local_path_override(
module_name = "rules_android",
path = "../../",
)

remote_android_extensions = use_extension(
"@rules_android//bzlmod_extensions:android_extensions.bzl",
"remote_android_tools_extensions")
use_repo(remote_android_extensions, "android_gmaven_r8", "android_tools")

register_toolchains(
"@rules_android//toolchains/android:android_default_toolchain",
"@rules_android//toolchains/android_sdk:android_sdk_tools",
)

android_sdk_repository_extension = use_extension("@rules_android//rules/android_sdk_repository:rule.bzl", "android_sdk_repository_extension")
use_repo(android_sdk_repository_extension, "androidsdk")

register_toolchains("@androidsdk//:sdk-toolchain", "@androidsdk//:all")

bazel_dep(name = "rules_jvm_external", version = "5.3")

# Load the maven extension from rules_jvm_external
maven = use_extension("@rules_jvm_external//:extensions.bzl", "maven")

maven.install(
name = "maven",
aar_import_bzl_label = "@rules_android//rules:rules.bzl",
artifacts = [
"com.google.guava:guava:32.1.2-android",
"com.arthenica:ffmpeg-kit-https:4.4.LTS",
],
repositories = [
"https://maven.google.com",
"https://repo1.maven.org/maven2",
],
use_starlark_android_rules = True,
)
use_repo(maven, "maven")




12 changes: 12 additions & 0 deletions examples/bundle/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
To build, ensure that the `ANDROID_HOME` environment variable is set to the path
to an Android SDK, and run:

```
bazel build app:assets
```

This will build application bundle containing a dynamic feature containing assets (named assets.txt). Verify with :

```
jar -tf bazel-bin/app/assets_unsigned.aab | grep assets.txt
```
73 changes: 73 additions & 0 deletions examples/bundle/WORKSPACE
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
load("@bazel_tools//tools/build_defs/repo:utils.bzl", "maybe")

local_repository(
name = "rules_android",
path = "../..", # rules_android's WORKSPACE relative to this inner workspace
)

# rules_license
http_archive(
name = "rules_license",
urls = [
"https://github.com/bazelbuild/rules_license/releases/download/1.0.0/rules_license-1.0.0.tar.gz",
],
sha256 = "26d4021f6898e23b82ef953078389dd49ac2b5618ac564ade4ef87cced147b38",
)

# rules_jvm_external
RULES_JVM_EXTERNAL_TAG = "6.5"
RULES_JVM_EXTERNAL_SHA = "3a4d56357851cf5b0dae538b3f3e0612a4f58925dfb3cadb2e0c4e87d51e629e"

http_archive(
name = "rules_jvm_external",
strip_prefix = "rules_jvm_external-%s" % RULES_JVM_EXTERNAL_TAG,
sha256 = RULES_JVM_EXTERNAL_SHA,
url = "https://github.com/bazelbuild/rules_jvm_external/releases/download/%s/rules_jvm_external-%s.tar.gz" % (RULES_JVM_EXTERNAL_TAG, RULES_JVM_EXTERNAL_TAG)
)

# bazel_features
BAZEL_FEATURES_VERSION = "1.20.0"
BAZEL_FEATURES_HASH = "c2596994cf63513bd44180411a4ac3ae95d32bf59148fcb6087a4642b3ffef11"
maybe(
http_archive,
name = "bazel_features",
sha256 = BAZEL_FEATURES_HASH,
strip_prefix = "bazel_features-" + BAZEL_FEATURES_VERSION,
url = "https://github.com/bazel-contrib/bazel_features/releases/download/v" + BAZEL_FEATURES_VERSION + "/bazel_features-v" + BAZEL_FEATURES_VERSION + ".tar.gz",
)
maybe(
http_archive,
name = "proto_bazel_features",
sha256 = BAZEL_FEATURES_HASH,
strip_prefix = "bazel_features-" + BAZEL_FEATURES_VERSION,
url = "https://github.com/bazel-contrib/bazel_features/releases/download/v" + BAZEL_FEATURES_VERSION + "/bazel_features-v" + BAZEL_FEATURES_VERSION + ".tar.gz",
)
load("@bazel_features//:deps.bzl", "bazel_features_deps")
bazel_features_deps()

# Skylib
http_archive(
name = "bazel_skylib",
sha256 = "bc283cdfcd526a52c3201279cda4bc298652efa898b10b4db0837dc51652756f",
urls = [
"https://github.com/bazelbuild/bazel-skylib/releases/download/1.7.1/bazel-skylib-1.7.1.tar.gz",
],
)
load("@bazel_skylib//:workspace.bzl", "bazel_skylib_workspace")
bazel_skylib_workspace()

load("@rules_android//:prereqs.bzl", "rules_android_prereqs")
rules_android_prereqs()
load("@rules_android//:defs.bzl", "rules_android_workspace")
rules_android_workspace()

load("@rules_android//rules:rules.bzl", "android_sdk_repository")
android_sdk_repository(
name = "androidsdk",
)

register_toolchains(
"@rules_android//toolchains/android:android_default_toolchain",
"@rules_android//toolchains/android_sdk:android_sdk_tools",
)
1 change: 1 addition & 0 deletions examples/bundle/WORKSPACE.bzlmod
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
workspace(name = "bundle")
22 changes: 22 additions & 0 deletions examples/bundle/app/AndroidManifest.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.examples.bundle.app" >

<uses-sdk
android:minSdkVersion="21"
android:targetSdkVersion="30" />

<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name="com.examples.bundle.app.BasicActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
19 changes: 19 additions & 0 deletions examples/bundle/app/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
load("@rules_android//android:rules.bzl", "android_application", "android_library")

android_application(
name = "assets",
manifest_values = {
"applicationId" : "com.examples.bundle.app",
"versionCode": "0",
},
feature_modules = ["//features/assets:feature_module"],
manifest = "AndroidManifest.xml",
deps = [":lib"],
)

android_library(
name = "lib",
srcs = ["BasicActivity.java"],
manifest = "AndroidManifest.xml",
resource_files = glob(["res/**"]),
)
52 changes: 52 additions & 0 deletions examples/bundle/app/BasicActivity.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
// Copyright 2022 The Bazel Authors. All rights reserved.
//
// 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.

package com.examples.bundle.app;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

/**
* The main activity of the Basic Sample App.
*/
public class BasicActivity extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.basic_activity);

final Button buttons[] = {
findViewById(R.id.button_id_fizz), findViewById(R.id.button_id_buzz),
};

for (Button b : buttons) {
b.setOnClickListener(
new View.OnClickListener() {
public void onClick(View v) {
TextView tv = findViewById(R.id.text_hello);
if (v.getId() == R.id.button_id_fizz) {
tv.setText("fizz");
} else if (v.getId() == R.id.button_id_buzz) {
tv.setText("buzz ");
}
}
});
}
}
}
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
23 changes: 23 additions & 0 deletions examples/bundle/app/res/layout/basic_activity.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<TextView
android:id="@+id/text_hello"
android:text="@string/hello_world"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

<Button
android:id="@+id/button_id_fizz"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="fizz" />
<Button
android:id="@+id/button_id_buzz"
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:text="buzz" />

</LinearLayout>
8 changes: 8 additions & 0 deletions examples/bundle/app/res/values/strings.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>

<string name="app_name" translatable="false">basicbundle</string>
<string name="hello_world" translatable="false">Hello world!</string>
<string name="action_settings" translatable="false">Settings</string>

</resources>
17 changes: 17 additions & 0 deletions examples/bundle/features/assets/BUILD
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
load("@rules_android//rules:rules.bzl", "android_library", "android_feature_module")

android_library(
name = "lib",
manifest = "src/AndroidManifest.xml",
assets = ["src/assets.txt"],
)

android_feature_module(
name = "feature_module",
custom_package = "com.example.bundle.features.assets",
manifest = "src/AndroidManifest.xml",
title = "asset_feature",
library = ":lib",
feature_name = "asset_feature",
visibility = ["//visibility:public"],
)
13 changes: 13 additions & 0 deletions examples/bundle/features/assets/src/AndroidManifest.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:dist="http://schemas.android.com/apk/distribution"
package="com.examples.bundle.features.assets">

<dist:module
dist:onDemand="true"
dist:instant="false"
dist:title="${MODULE_TITLE}">
<dist:fusing dist:include="true" />
</dist:module>

</manifest>
1 change: 1 addition & 0 deletions examples/bundle/features/assets/src/assets.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
This text originates from a dynamically loaded feature.
7 changes: 0 additions & 7 deletions rules/android_application/BUILD
Original file line number Diff line number Diff line change
Expand Up @@ -41,10 +41,3 @@ py_binary(
"@py_absl//absl/flags",
],
)

filegroup(
name = "merge_feature_manifests.par",
srcs = [":merge_feature_manifests"],
output_group = "python_zip_file",
visibility = ["//visibility:public"],
)
8 changes: 4 additions & 4 deletions rules/android_application/android_feature_module_rule.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -94,10 +94,10 @@ def get_feature_module_paths(fqn):
# Given a fqn to an android_feature_module, returns the absolute paths to
# all implicitly generated targets
return struct(
binary = Label("%s_bin" % fqn),
manifest_lib = Label("%s_AndroidManifest" % fqn),
title_strings_xml = Label("%s_title_strings_xml" % fqn),
title_lib = Label("%s_title_lib" % fqn),
binary = native.package_relative_label("%s_bin" % fqn),
manifest_lib = native.package_relative_label("%s_AndroidManifest" % fqn),
title_strings_xml = native.package_relative_label("%s_title_strings_xml" % fqn),
title_lib = native.package_relative_label("%s_title_lib" % fqn),
)

def android_feature_module_macro(_android_binary, _android_library, **attrs):
Expand Down
Loading