Puedes usar las marcas aconfig en código de Java, C, C++ y Rust. El sistema de compilación de AOSP lanza una herramienta llamada aconfig que se utiliza con el objetivo de generar una biblioteca específica para el lenguaje con métodos que sirven para acceder al valor de cada marca. Antes de poder generar la biblioteca, debes declarar marcas y agregarlas a la compilación.
Cómo declarar una marca de aconfig para Java
Para declarar una marca de aconfig para Java, haz lo siguiente:
En un directorio donde se encuentre el código nuevo, crea un archivo con la extensión
.aconfig
, por ejemplo,my_new_aconfig_flag_declarations.aconfig
. Un archivo .aconfig es un archivo .proto de texto que sigue un esquema estándar.Agrega una declaración de marca que se parezca a la siguiente:
package: "com.example.android.aconfig.demo.flags" container: "system" flag { name: "my_new_flag" namespace: "aconfig_demo_namespace" description: "This flag controls untested code" bug: "<none>" }
En la que:
package
proporciona una clave única cuando se combina con el nombre de la marca. En Java, establecerpackage
enfoo.bar
da como resultado una clase autogenerada llamadafoo.bar.Flags
. En C++, los métodos de acceso a las marcas se llamaríanfoo::bar::"flagname"
. Las marcas en el mismo archivo de declaración pertenecen al mismo paquete, pero varios archivos de declaración pueden aportar marcas al mismo paquete.container
define una recopilación de código que se compila y envía como objeto binario. Los contenedores válidos sonsystem
,vendor
,system_ext
,product
,name.of.apex
yname.of.apk
.name
contiene el nombre de la marca, que incluye solo letras en minúscula, guiones bajos y números.namespace
contiene el espacio de nombres para las contribuciones. Para determinar tu espacio de nombres, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar el espacio de nombres como lo desees.description
contiene una descripción breve de la función o el cambio que se marcó.bug
es el número de error asociado con la contribución del código nuevo. Para determinar tubug
, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar tu número de seguimiento de errores o<none>
.
Guarda el archivo y sal del editor.
Cómo configurar la compilación
Después de declarar la marca, configura la compilación para que genere el código de la biblioteca que se utilizó para acceder al valor de la marca.
En tu archivo de compilación
Android.bp
, agrega una secciónaconfig_declarations
similar a la siguiente:aconfig_declarations { name: "aconfig_demo_flags", package: "com.example.android.aconfig.demo.flags", srcs: [ "my_new_aconfig_flag_declarations.aconfig" ], }
En la que:
name
contiene el nombre de la declaración, que incluye solo letras en minúscula, guiones bajos y números.package
contiene el mismo nombre de paquete que se usó en la declaración.srcs
contiene el nombre del archivo.aconfig
en el que se declaró la marca.
Guarda el archivo y sal del editor.
Cómo declarar una marca de aconfig para C y C++
Para declarar una marca de aconfig para C y C++, haz lo siguiente:
En un directorio donde se encuentre el código nuevo, crea un archivo con la extensión
.aconfig
, por ejemplo,my_new_aconfig_flag_declarations.aconfig
. Un archivo .aconfig es un archivo .proto de texto que sigue un esquema estándar.Agrega una declaración de marca que se parezca a la siguiente:
package: "com.example.android.aconfig.demo.flags" container: "system" flag { name: "my_new_flag" namespace: "aconfig_demo_namespace" description: "This flag controls untested code" bug: "<none>" }
En la que:
package
proporciona una clave única cuando se combina con el nombre de la marca. En Java, establecerpackage
enfoo.bar
da como resultado una clase autogenerada llamadafoo.bar.Flags
. En C++, los métodos de acceso a las marcas se llamaríanfoo::bar::"flagname"
. Las marcas en el mismo archivo de declaración pertenecen al mismo paquete, pero varios archivos de declaración pueden aportar marcas al mismo paquete.container
define una recopilación de código que se compila y envía como objeto binario. Los contenedores válidos sonsystem
,vendor
,system_ext
,product
,name.of.apex
yname.of.apk
.name
contiene el nombre de la marca, que incluye solo letras en minúscula, guiones bajos y números.namespace
contiene el espacio de nombres para las contribuciones. Para determinar tu espacio de nombres, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar el espacio de nombres como lo desees.description
contiene una descripción breve de la función o el cambio que se marcó.bug
es el número de error asociado con la contribución del código nuevo. Para determinar tubug
, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar tu número de seguimiento de errores o<none>
.
Guarda el archivo y sal del editor.
Cómo configurar la compilación
Después de declarar la marca, configura la compilación para que genere el código de la biblioteca que se utilizó para acceder al valor de la marca.
En tu archivo de compilación
Android.bp
, agrega una secciónaconfig_declarations
similar a la siguiente:aconfig_declarations { name: "aconfig_demo_flags", package: "com.example.android.aconfig.demo.flags", srcs: [ "my_new_aconfig_flag_declarations.aconfig" ], }
En la que:
name
contiene el nombre de la declaración, que incluye solo letras en minúscula, guiones bajos y números.package
contiene el mismo nombre de paquete que se usó en la declaración.srcs
contiene el nombre del archivo de aconfig en el que se declaró la marca.
En el mismo archivo, crea un destino
cc_aconfig_library
similar al siguiente:cc_aconfig_library { name: "aconfig_demo_flags_c_lib", aconfig_declarations: "aconfig_demo_flags", }
En el que:
name
contiene el nombre de la biblioteca, que incluye solo letras en minúscula, guiones bajos y números.aconfig_declarations
contiene el mismoname
que se usó en la declaración.
El destino de compilación
cc_aconfig_library
invoca codegen de C o C++, que crea una biblioteca con el código generado durante el tiempo de compilación.La biblioteca de CC de aconfig es similar a un destino de biblioteca de CC, pero tiene opciones como
vendor_available
,product_available
,host_supported
yvndk
. Si el destino de compilación que depende de estacc_aconfig_library
requiere un cierto tipo de variantes, es posible que también debas agregar el parámetro de configuración correspondiente en el destino de la biblioteca de CC de aconfig. Por ejemplo, si el destino de compilación superior tienevendor_available
establecido entrue
, también podrías establecervendor_available
entrue
en este destino decc_aconfig_library
.Luego de que agregues ese destino de compilación, tu código podrá acceder a esta biblioteca. Puedes incluir la biblioteca con la sintaxis
static_lib
oshared_lib
. Si quieres agregar esta biblioteca comostatic_lib
, incluye una dependenciashared_lib
enserver_configurable_flags
. El paso 3 muestra cómo incluir la biblioteca de marcas del código generadas enlibexample_cpp_lib
.Crea un destino que use las marcas de aconfig, como la siguiente
cc_library
de ejemplo:cc_library { name: "libexample_cpp_lib", srcs: ["src/example_cpp_lib.cc"], double_loadable: true, cflags: [ "-Wall", "-Werror", "-Wno-unused-function", "-Wno-unused-parameter", ], header_libs: [ "jni_headers", ], shared_libs: [ "server_configurable_flags", ], static_libs: [ "aconfig_demo_flags_c_lib", ], export_include_dirs: ["src/include"], }
En el que:
shared_libs
incluye dependencias adicionales requeridas para las marcas de aconfig.static_libs
es el nombre de la biblioteca que crea la compilación de acuerdo con el camponame
decc_aconfig_library
del paso 2. Si creas una entradacc_library
con el nombre de la biblioteca estática, puedes usar marcas de aconfig en tu código.
Cómo declarar una marca de aconfig para Rust
Para declarar una marca de aconfig para Rust, haz lo siguiente:
En un directorio donde se encuentre el código nuevo, crea un archivo con la extensión
.aconfig
, por ejemplo,my_new_aconfig_flag_declarations.aconfig
. Un archivo .aconfig es un archivo .proto de texto que sigue un esquema estándar.Agrega una declaración de marca que se parezca a la siguiente:
package: "com.example.android.aconfig.demo.flags" container: "system" flag { name: "my_new_flag" namespace: "aconfig_demo_namespace" description: "This flag controls untested code" bug: "<none>" }
En la que:
package
proporciona una clave única cuando se combina con el nombre de la marca. En Java, establecerpackage
enfoo.bar
da como resultado una clase autogenerada llamadafoo.bar.Flags
. En C++, los métodos de acceso a las marcas se llamaríanfoo::bar::"flagname"
. Las marcas en el mismo archivo de declaración pertenecen al mismo paquete, pero varios archivos de declaración pueden aportar marcas al mismo paquete.container
define una recopilación de código que se compila y envía como objeto binario. Los contenedores válidos sonsystem
,vendor
,system_ext
,product
,name.of.apex
yname.of.apk
.name
contiene el nombre de la marca, que incluye solo letras en minúscula, guiones bajos y números.namespace
contiene el espacio de nombres para las contribuciones. Para determinar tu espacio de nombres, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar el espacio de nombres como lo desees.description
contiene una descripción breve de la función o el cambio que se marcó.bug
es el número de error asociado con la contribución del código nuevo. Para determinar tubug
, debes trabajar con tu revisor de Google designado. Si utilizas marcas de lanzamiento de funciones para mantener la estabilidad de tu propia duplicación de AOSP, puedes usar tu número de seguimiento de errores o<none>
.
Guarda el archivo y sal del editor.
Cómo configurar la compilación
Después de declarar la marca, configura la compilación para que genere el código de la biblioteca que se utilizó para acceder al valor de la marca.
En tu archivo de compilación
Android.bp
, agrega una secciónaconfig_declarations
similar a la siguiente:aconfig_declarations { name: "aconfig_demo_flags", package: "com.example.android.aconfig.demo.flags", srcs: [ "my_new_aconfig_flag_declarations.aconfig" ], }
En la que:
name
contiene el nombre de la declaración, que incluye solo letras en minúscula, guiones bajos y números.package
contiene el mismo nombre de paquete que se usó en la declaración.srcs
contiene el nombre del archivo de aconfig en el que se declaró la marca.
Crea un destino
rust_aconfig_library
que se parezca al ejemplo que se muestra a continuación. Este destino invoca codegen de Rust y crea una biblioteca de Rust con el código generado durante el tiempo de compilación.rust_aconfig_library { name: "libaconfig_demo_flags_rust", crate_name: "aconfig_demo_flags_rust", aconfig_declarations: "aconfig_demo_flags", }
En la que:
name
contiene el nombre de la declaración, que incluye solo letras en minúscula, guiones bajos y números.crate_name
contiene el mismo nombre de paquete que se usó en la declaración.aconfig_declarations
contiene el mismoname
que se usó en la declaración.
Con ese cambio, tu código puede depender de esta biblioteca de Rust.
En el mismo archivo, crea una entrada
rust_library
similar a la siguiente:rust_library { name: "libexample_lib", rustlibs: [ "libaconfig_demo_flags_rust", ] }
Este ejemplo permite que los destinos de compilación
libexample_demo_flags_rust
del código fuente incluyan la biblioteca de marcas del código generadas.Guarda el archivo y sal del editor.