Quy tắc
j2objc_library
Xem nguồn quy tắcj2objc_library(name, deps, compatible_with, deprecation, distribs, entry_classes, features, jre_deps, licenses, restricted_to, tags, target_compatible_with, testonly, visibility)
Quy tắc này sử dụng J2ObjC để dịch các tệp nguồn Java sang Target-C. Sau đó, các tệp này có thể được dùng làm phần phụ thuộc của objc_library và objc_binary. Bạn có thể xem thông tin chi tiết về J2ObjC tại trang web của J2ObjC
Bạn có thể chỉ định cờ chuyển đổi J2ObjC tuỳ chỉnh bằng cách sử dụng cờ bản dựng --j2objc_translation_flags
trong dòng lệnh.
Xin lưu ý rằng các tệp đã dịch có trong mục tiêu j2objc_library sẽ được biên dịch bằng cấu hình biên dịch mặc định, có cùng cấu hình như đối với các nguồn của quy tắc objc_library không có tuỳ chọn biên dịch được chỉ định trong các thuộc tính.
Ngoài ra, mã được tạo sẽ được loại bỏ trùng lặp ở cấp mục tiêu, chứ không phải ở cấp nguồn. Nếu có hai mục tiêu Java khác nhau bao gồm các tệp nguồn Java giống nhau, thì bạn có thể thấy lỗi biểu tượng trùng lặp tại thời điểm liên kết. Cách đúng để giải quyết vấn đề này là di chuyển các tệp nguồn Java được chia sẻ vào một mục tiêu chung riêng biệt có thể được phụ thuộc.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
deps
|
Danh sách nhãn; mặc định là j2objc_library , java_library , java_import và java_proto_library chứa các tệp Java sẽ được dịch sang Mục tiêu-C.
Tất cả các mục tiêu Bản dịch J2ObjC hoạt động theo các cách khác nhau tuỳ thuộc vào loại tệp nguồn Java có trong đóng chuyển tiếp. Đối với mỗi tệp nguồn .java có trong Người dùng có thể nhập các tệp tiêu đề do J2ObjC tạo trong mã của họ. Đường dẫn nhập cho các tệp này là đường dẫn gốc tương đối của các cấu phần phần mềm Java ban đầu. Ví dụ:
Nếu các quy tắc proto_library nằm trong quá trình đóng bắc cầu của quy tắc này, thì các proto J2ObjC cũng sẽ được tạo, biên dịch và liên kết ở cấp độ nhị phân. Đối với proto |
entry_classes
|
Danh sách chuỗi; mặc định là --j2objc_dead_code_removal
đang bật. Các lớp Java phải được chỉ định trong tên chính tắc như được xác định trong Thông số kỹ thuật ngôn ngữ Java.
Khi cờ --j2objc_dead_code_removal được chỉ định, danh sách các lớp truy cập sẽ được thu thập theo cách bắc cầu và dùng làm điểm truy cập để tiến hành phân tích mã lỗi.
Sau đó, các lớp không dùng đến sẽ bị xoá khỏi gói ứng dụng ObjC cuối cùng.
|
jre_deps
|
Danh sách nhãn; mặc định là j2objc_library này. Theo mặc định, chỉ chức năng JRE chính mới được liên kết.
|
objc_import
Xem nguồn quy tắcobjc_import(name, deps, hdrs, alwayslink, archives, compatible_with, deprecation, distribs, features, includes, licenses, restricted_to, sdk_dylibs, sdk_frameworks, sdk_includes, tags, target_compatible_with, testonly, textual_hdrs, visibility, weak_sdk_frameworks)
Quy tắc này đóng gói một thư viện tĩnh đã được biên dịch dưới dạng một tệp .a
. Tệp này cũng cho phép xuất tiêu đề và tài nguyên bằng cách sử dụng cùng các thuộc tính mà objc_library
hỗ trợ.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
deps
|
Danh sách nhãn; mặc định là |
hdrs
|
Danh sách nhãn; mặc định là Các tiêu đề này mô tả giao diện công khai của thư viện và sẽ được cung cấp để đưa vào các nguồn trong quy tắc này hoặc trong các quy tắc phụ thuộc. Thay vào đó, các tiêu đề không dành cho ứng dụng của thư viện này phải được liệt kê trong thuộc tính srcs. Các mô-đun này sẽ được biên dịch riêng biệt với nguồn nếu bạn bật các mô-đun. |
alwayslink
|
Boolean; giá trị mặc định là srcs và non_arc_srcs , ngay cả khi một số tệp không chứa ký hiệu nào được tệp nhị phân tham chiếu.
Điều này sẽ hữu ích nếu mã không được gọi rõ ràng bằng mã trong tệp nhị phân, chẳng hạn như khi mã của bạn đăng ký nhận một số lệnh gọi lại do dịch vụ nào đó cung cấp.
|
archives
|
Danh sách nhãn; bắt buộc Danh sách các tệp.a được cung cấp cho các mục tiêu Target-C phụ thuộc vào mục tiêu này.
|
includes
|
Danh sách chuỗi; mặc định là #include/#import cần thêm vào mục tiêu này
và tất cả các mục tiêu phụ thuộc.
Tính năng này nhằm hỗ trợ các thư viện nguồn mở và bên thứ ba không chỉ định toàn bộ đường dẫn không gian làm việc trong các câu lệnh #import/#include .
Các đường dẫn được diễn giải tương ứng với thư mục gói, đồng thời các tệp gen và thư mục gốc của thùng (ví dụ: Không giống như COPTS, những cờ này được thêm cho quy tắc này và mọi quy tắc phụ thuộc vào quy tắc đó. (Lưu ý: không phải quy tắc mà nó phụ thuộc vào!) Hãy thật cẩn thận vì việc này có thể gây ảnh hưởng sâu rộng. Khi nghi ngờ, hãy thêm cờ "-iTrích dẫn" vào COPTS. |
sdk_dylibs
|
Danh sách chuỗi; mặc định là |
sdk_frameworks
|
Danh sách chuỗi; mặc định là Khi liên kết một tệp nhị phân Apple cấp cao nhất, tất cả các khung SDK có trong biểu đồ phần phụ thuộc bắc cầu của tệp nhị phân đó đều được liên kết. |
sdk_includes
|
Danh sách chuỗi; mặc định là #include/#import cần thêm vào mục tiêu này và tất cả các mục tiêu phụ thuộc, trong đó mỗi đường dẫn đều tương ứng với $(SDKROOT)/usr/include .
|
textual_hdrs
|
Danh sách nhãn; mặc định là |
weak_sdk_frameworks
|
Danh sách chuỗi; mặc định là |
objc_library
Xem nguồn quy tắcobjc_library(name, deps, srcs, data, hdrs, alwayslink, compatible_with, copts, defines, deprecation, distribs, enable_modules, exec_compatible_with, exec_properties, features, implementation_deps, includes, licenses, linkopts, module_map, module_name, non_arc_srcs, pch, restricted_to, sdk_dylibs, sdk_frameworks, sdk_includes, tags, target_compatible_with, testonly, textual_hdrs, toolchains, visibility, weak_sdk_frameworks)
Quy tắc này tạo ra một thư viện tĩnh từ các tệp nguồn Target-C đã cho.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
deps
|
Danh sách nhãn; mặc định là |
srcs
|
Danh sách nhãn; mặc định là |
hdrs
|
Danh sách nhãn; mặc định là Các tiêu đề này mô tả giao diện công khai của thư viện và sẽ được cung cấp để đưa vào các nguồn trong quy tắc này hoặc trong các quy tắc phụ thuộc. Thay vào đó, các tiêu đề không dành cho ứng dụng của thư viện này phải được liệt kê trong thuộc tính srcs. Các mô-đun này sẽ được biên dịch riêng biệt với nguồn nếu bạn bật các mô-đun. |
alwayslink
|
Boolean; giá trị mặc định là srcs và non_arc_srcs , ngay cả khi một số tệp không chứa ký hiệu nào được tệp nhị phân tham chiếu.
Điều này sẽ hữu ích nếu mã không được gọi rõ ràng bằng mã trong tệp nhị phân, chẳng hạn như khi mã của bạn đăng ký nhận một số lệnh gọi lại do dịch vụ nào đó cung cấp.
|
copts
|
Danh sách chuỗi; mặc định là Xin lưu ý rằng đối với dự án Xcode đã tạo, các đường dẫn thư mục được chỉ định bằng cờ "-I" trong copt sẽ được phân tích cú pháp, thêm "$(WORKSPACE_ROOT)/" nếu chúng là đường dẫn tương đối và được thêm vào đường dẫn tìm kiếm ở tiêu đề cho mục tiêu Xcode được liên kết. |
defines
|
Danh sách chuỗi; mặc định là -D bổ sung để truyền đến trình biên dịch. Các mã này phải ở dạng KEY=VALUE hoặc đơn giản là KEY và không chỉ được chuyển cho trình biên dịch cho mục tiêu này (như copts ) mà còn được truyền đến tất cả người phụ thuộc objc_ của mục tiêu này.
Áp dụng tuỳ chọn thay thế "Tạo biến" và tạo mã thông báo shell Bourne.
|
enable_modules
|
Boolean; giá trị mặc định là |
implementation_deps
|
Danh sách nhãn; mặc định là deps , tiêu đề và đường dẫn của những thư viện này (và tất cả các phần phụ thuộc bắc cầu của thư viện đó) chỉ được dùng để biên dịch thư viện này chứ không phải các thư viện phụ thuộc vào thư viện đó. Các thư viện được chỉ định bằng implementation_deps vẫn được liên kết trong các mục tiêu nhị phân phụ thuộc vào thư viện này.
|
includes
|
Danh sách chuỗi; mặc định là #include/#import cần thêm vào mục tiêu này
và tất cả các mục tiêu phụ thuộc.
Tính năng này nhằm hỗ trợ các thư viện nguồn mở và bên thứ ba không chỉ định toàn bộ đường dẫn không gian làm việc trong các câu lệnh #import/#include .
Các đường dẫn được diễn giải tương ứng với thư mục gói, đồng thời các tệp gen và thư mục gốc của thùng (ví dụ: Không giống như COPTS, những cờ này được thêm cho quy tắc này và mọi quy tắc phụ thuộc vào quy tắc đó. (Lưu ý: không phải quy tắc mà nó phụ thuộc vào!) Hãy thật cẩn thận vì việc này có thể gây ảnh hưởng sâu rộng. Khi nghi ngờ, hãy thêm cờ "-iTrích dẫn" vào COPTS. |
linkopts
|
Danh sách chuỗi; mặc định là |
module_map
|
Nhãn; mặc định là |
module_name
|
Chuỗi; giá trị mặc định là |
non_arc_srcs
|
Danh sách nhãn; mặc định là |
pch
|
Nhãn; mặc định là |
sdk_dylibs
|
Danh sách chuỗi; mặc định là |
sdk_frameworks
|
Danh sách chuỗi; mặc định là Khi liên kết một tệp nhị phân Apple cấp cao nhất, tất cả các khung SDK có trong biểu đồ phần phụ thuộc bắc cầu của tệp nhị phân đó đều được liên kết. |
sdk_includes
|
Danh sách chuỗi; mặc định là #include/#import cần thêm vào mục tiêu này và tất cả các mục tiêu phụ thuộc, trong đó mỗi đường dẫn đều tương ứng với $(SDKROOT)/usr/include .
|
textual_hdrs
|
Danh sách nhãn; mặc định là |
weak_sdk_frameworks
|
Danh sách chuỗi; mặc định là |
available_xcodes
Xem nguồn quy tắcavailable_xcodes(name, default, deprecation, distribs, features, licenses, tags, testonly, versions, visibility)
Một thực thể quy tắc xcode_config
có thể phụ thuộc vào hai mục tiêu của quy tắc này để chỉ ra các phiên bản xcode có sẵn từ xa và cục bộ.
Điều này cho phép lựa chọn phiên bản xcode chính thức từ các mã xcode có sẵn chung.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
default
|
Nhãn; không thể định cấu hình; bắt buộc Phiên bản xcode mặc định cho nền tảng này. |
versions
|
Danh sách nhãn; không thể định cấu hình; giá trị mặc định là |
xcode_config
Xem nguồn quy tắcxcode_config(name, default, deprecation, distribs, features, licenses, local_versions, remote_versions, tags, testonly, versions, visibility)
Một mục tiêu duy nhất của quy tắc này có thể được tham chiếu bằng cờ bản dựng --xcode_version_config
để chuyển cờ --xcode_version
thành phiên bản xcode chính thức được chấp nhận.
Điều này cho phép lựa chọn phiên bản xcode chính thức từ một số bí danh đã đăng ký.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
default
|
Nhãn; không thể định cấu hình; giá trị mặc định là xcode_version đã cung cấp chỉ định sẽ được sử dụng nếu không có cờ bản dựng xcode_version nào được chỉ định. Đây là yêu cầu bắt buộc nếu bạn thiết lập bất kỳ versions nào. Bạn có thể không thiết lập được giá trị này nếu đã đặt remote_versions hoặc local_versions .
|
local_versions
|
Nhãn; không thể định cấu hình; giá trị mặc định là xcode_version trên thiết bị.
Các biến này được dùng cùng với local_versions để chọn một phiên bản có thể sử dụng chung. Bạn có thể không thiết lập được giá trị này nếu đã đặt versions .
|
remote_versions
|
Nhãn; không thể định cấu hình; giá trị mặc định là xcode_version có thể sử dụng từ xa.
Các biến này được dùng cùng với remote_versions để chọn một phiên bản có thể sử dụng chung. Bạn có thể không thiết lập được giá trị này nếu đã đặt versions .
|
versions
|
Danh sách nhãn; không thể định cấu hình; giá trị mặc định là xcode_version được chấp nhận.
Nếu giá trị của cờ bản dựng xcode_version khớp với một trong các bí danh hoặc số phiên bản của bất kỳ mục tiêu xcode_version nào đã cho, thì mục tiêu phù hợp đó sẽ được sử dụng. Bạn có thể không thiết lập được giá trị này nếu đã đặt remote_versions hoặc local_versions .
|
xcode_version
Xem nguồn quy tắcxcode_version(name, default_ios_sdk_version, default_macos_sdk_version, default_tvos_sdk_version, default_visionos_sdk_version, default_watchos_sdk_version, deprecation, distribs, features, licenses, tags, testonly, version, visibility)
Đại diện cho một phiên bản xcode chính thức có bí danh được chấp nhận cho phiên bản xcode đó.
Xem quy tắc xcode_config
.
Đối số
Thuộc tính | |
---|---|
name |
Tên; bắt buộc Tên duy nhất cho mục tiêu này. |
default_ios_sdk_version
|
Chuỗi; không thể định cấu hình; giá trị mặc định là ios_sdk_version sẽ ghi đè giá trị được chỉ định ở đây.
|
default_macos_sdk_version
|
Chuỗi; không thể định cấu hình; giá trị mặc định là macos_sdk_version sẽ ghi đè giá trị được chỉ định ở đây.
|
default_tvos_sdk_version
|
Chuỗi; không thể định cấu hình; giá trị mặc định là tvos_sdk_version sẽ ghi đè giá trị được chỉ định ở đây.
|
default_visionos_sdk_version
|
Chuỗi; không thể định cấu hình; giá trị mặc định là visionos_sdk_version sẽ ghi đè giá trị được chỉ định ở đây.
|
default_watchos_sdk_version
|
Chuỗi; không thể định cấu hình; giá trị mặc định là watchos_sdk_version sẽ ghi đè giá trị được chỉ định ở đây.
|
version
|
Chuỗi; không thể định cấu hình; bắt buộc Số phiên bản chính thức của một phiên bản Xcode. |