From 5bd3b092cf390c61f5089849a3f678a56bbb5fb7 Mon Sep 17 00:00:00 2001 From: Wojciech Kulik <3128467+wojciech-kulik@users.noreply.github.com> Date: Sun, 20 Oct 2024 11:38:37 +0200 Subject: [PATCH] feat!: improved xcodebuild performance by blocking Apple domain BREAKING CHANGE: (optional) please see `:h xcodebuild.xcodebuild-offline` to enable tool that improves build speed. More details about this issue here (#201): https://github.com/wojciech-kulik/xcodebuild.nvim/issues/201#issuecomment-2423828065 --- README.md | 7 +- doc/xcodebuild.txt | 85 +++++++++++++- lua/xcodebuild/core/config.lua | 2 + lua/xcodebuild/core/xcode.lua | 9 ++ lua/xcodebuild/docs/features.lua | 2 +- lua/xcodebuild/docs/ios17.lua | 3 +- lua/xcodebuild/docs/requirements.lua | 2 +- lua/xcodebuild/health.lua | 65 ++++++++--- lua/xcodebuild/init.lua | 2 + .../integrations/xcodebuild-offline.lua | 107 ++++++++++++++++++ lua/xcodebuild/project/appdata.lua | 2 + scripts/help-update.sh | 101 +++++++++-------- tools/xcodebuild_offline | 38 +++++++ 13 files changed, 349 insertions(+), 76 deletions(-) create mode 100644 lua/xcodebuild/integrations/xcodebuild-offline.lua create mode 100755 tools/xcodebuild_offline diff --git a/README.md b/README.md index 6b919a6..154d3b4 100644 --- a/README.md +++ b/README.md @@ -119,10 +119,7 @@ return { Install external tools: ```shell -brew install xcode-build-server -brew install xcbeautify -brew install ruby -brew install pipx +brew install xcode-build-server xcbeautify ruby pipx gem install xcodeproj pipx install pymobiledevice3 ``` @@ -335,6 +332,8 @@ vim.keymap.set("n", "xa", "XcodebuildCodeActions", { desc = "Sh remote_debugger = nil, -- optional path to local copy of remote_debugger (check out README for details) remote_debugger_port = 65123, -- port used by remote debugger (passed to pymobiledevice3) focus_simulator_on_app_launch = true, -- focus simulator window when app is launched + run_xcodebuild_in_offline_mode = false, -- significantly speeds up xcodebuild by disabling network requests (requires configuration, see `:h xcodebuild.xcodebuild-offline`) + xcodebuild_offline = nil, -- optional path to local copy of xcodebuild-offline (see `:h xcodebuild.xcodebuild-offline`) }, logs = { -- build & test logs auto_open_on_success_tests = false, -- open logs when tests succeeded diff --git a/doc/xcodebuild.txt b/doc/xcodebuild.txt index 2fc34c3..a1a4141 100644 --- a/doc/xcodebuild.txt +++ b/doc/xcodebuild.txt @@ -44,6 +44,7 @@ neo-tree.nvim Integration ··················· |xcodebuild.int oil.nvim Integration ························ |xcodebuild.integrations.oil-nvim| Quick Test Framework Integration ··············· |xcodebuild.integrations.quick| xcode-build-server Integration ···· |xcodebuild.integrations.xcode-build-server| +Xcodebuild Workaround ············· |xcodebuild.integrations.xcodebuild-offline| Pickers ················································ |xcodebuild.ui.pickers| Helpers ··················································· |xcodebuild.helpers| Lua Utils ···················································· |xcodebuild.util| @@ -92,6 +93,8 @@ M.setup({options}) *xcodebuild.setup* remote_debugger = nil, -- optional path to local copy of remote_debugger (check out README for details) remote_debugger_port = 65123, -- port used by remote debugger (passed to pymobiledevice3) focus_simulator_on_app_launch = true, -- focus simulator window when app is launched + run_xcodebuild_in_offline_mode = false, -- significantly speeds up xcodebuild by disabling network requests (requires configuration, see `:h xcodebuild.xcodebuild-offline`) + xcodebuild_offline = nil, -- optional path to local copy of xcodebuild-offline (see `:h xcodebuild.xcodebuild-offline`) }, logs = { -- build & test logs auto_open_on_success_tests = false, -- open logs when tests succeeded @@ -247,7 +250,7 @@ Availability of features 🔐 - requires passwordless `sudo` permission to `tools/remote_debugger` - script (see |xcodebuild.sudo|). + script (see |xcodebuild.ios17|). 🛠️ - available if pymobiledevice3 is installed. @@ -290,7 +293,7 @@ or just: < To debug on physical devices with iOS 17+ you will need to set up `sudo`, -see |xcodebuild.sudo| to learn more. +see |xcodebuild.ios17| to learn more. ============================================================================== @@ -543,8 +546,7 @@ Sample `lualine` integration: ============================================================================== Debugging On iOS 17+ Device *xcodebuild.integrations.ios17* - *xcodebuild.integrations.sudo* - *xcodebuild.sudo* + *xcodebuild.ios17* Since iOS 17, a new secure connection between Mac and mobile devices is required. Xcodebuild.nvim uses `pymobiledevice3` to establish a special trusted tunnel that is later used for debugging. However, this operation @@ -1705,6 +1707,7 @@ AppData *xcodebuild.project.appdata.AppData* {GETSNAPSHOTS_TOOL} (string) # The name of the getsnapshots tool. {PROJECT_HELPER_TOOL} (string) # The name of the project helper tool. {REMOTE_DEBUGGER_TOOL} (string) # The name of the remote debugger tool. + {XCODEBUILD_OFFLINE_TOOL} (string) # The name of the xcodebuild offline tool. M.tool_path({name}) *xcodebuild.project.appdata.tool_path* @@ -3699,6 +3702,80 @@ M.run_config({projectCommand}, {scheme}) (number) job id +============================================================================== +Xcodebuild Workaround *xcodebuild.integrations.xcodebuild-offline* + + *xcodebuild.xcodebuild-offline* + +This module provides a workaround for the issue with slow `xcodebuild` command. + +The issue is caused by the fact that `xcodebuild` tries to connect to the Apple +servers before building the project, which can take 20 seconds or more. +Usually, those requests are not necessary, but they slow down each build. + +This module provides a workaround by mapping Apple servers to localhost in the +`/etc/hosts` file during the build. It is a temporary solution and should be +used with caution. + +Keep in mind that disabling access to `developerservices2.apple.com` for +`xcodebuild` may cause some issues with the build process. It will disable +things like registering devices, capabilities, and other network-related +features. Therefore, it's best to use it when you are working just on the +code and don't need updating project settings. + +To enable this workaround, set `commands.run_xcodebuild_in_offline_mode` +to `true` in the configuration. + +👉 Passwordless access to `xcodebuild_offline` + +This workaround requires `sudo` to update the `/etc/hosts` file. +Make sure to use the command below, otherwise you may break your `sudo` command: + +>bash + sudo visudo -f /etc/sudoers +< + +Append this line, but first update the path and the username: + +>bash + YOUR_USERNAME ALL = (ALL) NOPASSWD: /Users/YOUR_USERNAME/.local/share/nvim/lazy/xcodebuild.nvim/tools/xcodebuild_offline +< + +👉 Creating a local copy of `xcodebuild_offline` + +If you don't want to configure the passwordless permission to the file +that could be changed in the future, you can make a local copy of this +script, set your local path in the config `commands.xcodebuild_offline`, +and update `/etc/sudoers` accordingly. + +Please remember that you will have to update this file manually if it +changes in the future. + + + +More details about this issue can be found here: + https://github.com/wojciech-kulik/xcodebuild.nvim/issues/201#issuecomment-2423828065 + + + *xcodebuild.integrations.xcodebuild-offline.is_enabled* +M.is_enabled() + Returns whether the `xcodebuild` command should be run in offline mode. + + Returns: ~ + (boolean) + + + *xcodebuild.integrations.xcodebuild-offline.wrap_command_if_needed* +M.wrap_command_if_needed({command}) + Wraps the `xcodebuild` command with the workaround script if needed. + + Parameters: ~ + {command} (string) + + Returns: ~ + (string) + + ============================================================================== Pickers *xcodebuild.ui.pickers* diff --git a/lua/xcodebuild/core/config.lua b/lua/xcodebuild/core/config.lua index 5e31abf..e928927 100644 --- a/lua/xcodebuild/core/config.lua +++ b/lua/xcodebuild/core/config.lua @@ -29,6 +29,8 @@ local defaults = { remote_debugger = nil, -- optional path to local copy of remote_debugger (check out README for details) remote_debugger_port = 65123, -- port used by remote debugger (passed to pymobiledevice3) focus_simulator_on_app_launch = true, -- focus simulator window when app is launched + run_xcodebuild_in_offline_mode = false, -- significantly speeds up xcodebuild by disabling network requests (requires configuration, see `:h xcodebuild.xcodebuild-offline`) + xcodebuild_offline = nil, -- optional path to local copy of xcodebuild-offline (see `:h xcodebuild.xcodebuild-offline`) }, logs = { -- build & test logs auto_open_on_success_tests = false, -- open logs when tests succeeded diff --git a/lua/xcodebuild/core/xcode.lua b/lua/xcodebuild/core/xcode.lua index cc58111..eafd3bb 100644 --- a/lua/xcodebuild/core/xcode.lua +++ b/lua/xcodebuild/core/xcode.lua @@ -64,6 +64,7 @@ local util = require("xcodebuild.util") local notifications = require("xcodebuild.broadcasting.notifications") local constants = require("xcodebuild.core.constants") +local xcodebuildOffline = require("xcodebuild.integrations.xcodebuild-offline") local M = {} local CANCELLED_CODE = 143 @@ -144,6 +145,7 @@ end ---@return number # job id function M.get_destinations(projectCommand, scheme, callback) local command = "xcodebuild -showdestinations " .. projectCommand .. " -scheme '" .. scheme .. "'" + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { stdout_buffered = true, @@ -185,6 +187,7 @@ end ---@return number # job id function M.get_schemes(projectCommand, callback) local command = "xcodebuild " .. projectCommand .. " -list" + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { stdout_buffered = true, @@ -254,6 +257,7 @@ end ---@return number # job id function M.get_project_information(xcodeproj, callback) local command = "xcodebuild -project '" .. xcodeproj .. "' -list" + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { stdout_buffered = true, @@ -304,6 +308,7 @@ end ---@return number # job id function M.get_testplans(projectCommand, scheme, callback) local command = "xcodebuild test " .. projectCommand .. " -scheme '" .. scheme .. "' -showTestPlans" + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { stdout_buffered = true, @@ -346,6 +351,7 @@ function M.build_project(opts) .. opts.destination .. "'" .. (string.len(opts.extraBuildArgs) > 0 and " " .. opts.extraBuildArgs or "") + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { stdout_buffered = false, @@ -393,6 +399,7 @@ function M.get_build_settings(platform, projectCommand, scheme, xcodeprojPath, c .. "' -showBuildSettings" .. " -sdk " .. sdk + command = xcodebuildOffline.wrap_command_if_needed(command) if config then command = command .. " -configuration '" .. config .. "'" @@ -747,6 +754,7 @@ function M.enumerate_tests(opts, callback) .. "' -disableAutomaticPackageResolution -skipPackageUpdates -parallelizeTargets" .. " -test-enumeration-style flat" .. (string.len(opts.extraTestArgs) > 0 and " " .. opts.extraTestArgs or "") + command = xcodebuildOffline.wrap_command_if_needed(command) return vim.fn.jobstart(command, { on_exit = function(_, code, _) @@ -807,6 +815,7 @@ function M.run_tests(opts) .. opts.testPlan .. "'" .. (string.len(opts.extraTestArgs) > 0 and " " .. opts.extraTestArgs or "") + command = xcodebuildOffline.wrap_command_if_needed(command) if opts.testsToRun then for _, test in ipairs(opts.testsToRun) do diff --git a/lua/xcodebuild/docs/features.lua b/lua/xcodebuild/docs/features.lua index 030ebd7..145956b 100644 --- a/lua/xcodebuild/docs/features.lua +++ b/lua/xcodebuild/docs/features.lua @@ -38,7 +38,7 @@ --- --- --- 🔐 - requires passwordless `sudo` permission to `tools/remote_debugger` ---- script (see |xcodebuild.sudo|). +--- script (see |xcodebuild.ios17|). --- --- 🛠️ - available if pymobiledevice3 is installed. --- diff --git a/lua/xcodebuild/docs/ios17.lua b/lua/xcodebuild/docs/ios17.lua index 3d98a65..069bbb7 100644 --- a/lua/xcodebuild/docs/ios17.lua +++ b/lua/xcodebuild/docs/ios17.lua @@ -1,6 +1,5 @@ ---@mod xcodebuild.integrations.ios17 Debugging On iOS 17+ Device ----@tag xcodebuild.integrations.sudo ----@tag xcodebuild.sudo +---@tag xcodebuild.ios17 ---@brief [[ ---Since iOS 17, a new secure connection between Mac and mobile devices is ---required. Xcodebuild.nvim uses `pymobiledevice3` to establish a special diff --git a/lua/xcodebuild/docs/requirements.lua b/lua/xcodebuild/docs/requirements.lua index a36a21a..137ea65 100644 --- a/lua/xcodebuild/docs/requirements.lua +++ b/lua/xcodebuild/docs/requirements.lua @@ -33,7 +33,7 @@ ---< --- ---To debug on physical devices with iOS 17+ you will need to set up `sudo`, ----see |xcodebuild.sudo| to learn more. +---see |xcodebuild.ios17| to learn more. --- ---@brief ]] diff --git a/lua/xcodebuild/health.lua b/lua/xcodebuild/health.lua index b5c1c5a..09ddbe5 100644 --- a/lua/xcodebuild/health.lua +++ b/lua/xcodebuild/health.lua @@ -277,31 +277,67 @@ local function check_os() end end -local function check_sudo() +local function has_sudo_access(path) + local util = require("xcodebuild.util") + local permissions = util.shell("sudo -l 2>/dev/null") + + for _, line in ipairs(permissions) do + if line:match("NOPASSWD.*" .. path) then + return true + end + end + + return false +end + +local function check_remote_debugger_sudo() local deviceProxy = require("xcodebuild.platform.device_proxy") if not deviceProxy.is_installed() then return end - start("Checking passwordless sudo") + start("Checking passwordless sudo for remote_debugger") local config = require("xcodebuild.core.config") local appdata = require("xcodebuild.project.appdata") - local util = require("xcodebuild.util") - local path = config.options.commands.remote_debugger or appdata.tool_path(appdata.REMOTE_DEBUGGER_TOOL) - local permissions = util.shell("sudo -l 2>/dev/null") + local path = config.options.commands.remote_debugger + and vim.fn.expand(config.options.commands.remote_debugger) + or appdata.tool_path(appdata.REMOTE_DEBUGGER_TOOL) - for _, line in ipairs(permissions) do - if line:match("NOPASSWD.*" .. path) then - ok("sudo: configured") - return - end + if has_sudo_access(path) then + ok("sudo: configured") + else + warn("passwordless sudo permission for `remote_debugger` is not configured.") + warn("debugging on physical devices with iOS 17+ will not work.") + warn("see `:h xcodebuild.ios17` for more information.") end +end + +local function check_xcodebuild_offline_sudo() + local isEnabled = require("xcodebuild.integrations.xcodebuild-offline").is_enabled() + if not isEnabled then + start("Checking xcodebuild_offline tool") + warn("tool not enabled - builds might be slower.") + warn("see `:h xcodebuild.xcodebuild-offline` for more information.") + return + end + + start("Checking passwordless sudo for xcodebuild_offline") - warn("sudo: passwordless permission for `remote_debugger` is not configured.") - warn("debugging on physical devices with iOS 17+ will not work.") - warn("see `:h xcodebuild.sudo` for more information.") + local config = require("xcodebuild.core.config") + local appdata = require("xcodebuild.project.appdata") + + local path = config.options.commands.xcodebuild_offline + and vim.fn.expand(config.options.commands.xcodebuild_offline) + or appdata.tool_path(appdata.XCODEBUILD_OFFLINE_TOOL) + + if has_sudo_access(path) then + ok("sudo: configured") + else + error("passwordless sudo permission for `xcodebuild_offline` is not configured.") + error("see `:h xcodebuild.xcodebuild-offline` for more information.") + end end local function check_plugin_commit() @@ -367,7 +403,8 @@ M.check = function() start("Checking .nvim/xcodebuild/settings.json") check_xcodebuild_settings() - check_sudo() + check_xcodebuild_offline_sudo() + check_remote_debugger_sudo() end return M diff --git a/lua/xcodebuild/init.lua b/lua/xcodebuild/init.lua index 547c117..de890df 100644 --- a/lua/xcodebuild/init.lua +++ b/lua/xcodebuild/init.lua @@ -109,6 +109,8 @@ end --- remote_debugger = nil, -- optional path to local copy of remote_debugger (check out README for details) --- remote_debugger_port = 65123, -- port used by remote debugger (passed to pymobiledevice3) --- focus_simulator_on_app_launch = true, -- focus simulator window when app is launched +--- run_xcodebuild_in_offline_mode = false, -- significantly speeds up xcodebuild by disabling network requests (requires configuration, see `:h xcodebuild.xcodebuild-offline`) +--- xcodebuild_offline = nil, -- optional path to local copy of xcodebuild-offline (see `:h xcodebuild.xcodebuild-offline`) --- }, --- logs = { -- build & test logs --- auto_open_on_success_tests = false, -- open logs when tests succeeded diff --git a/lua/xcodebuild/integrations/xcodebuild-offline.lua b/lua/xcodebuild/integrations/xcodebuild-offline.lua new file mode 100644 index 0000000..a498dcf --- /dev/null +++ b/lua/xcodebuild/integrations/xcodebuild-offline.lua @@ -0,0 +1,107 @@ +---@mod xcodebuild.integrations.xcodebuild-offline Xcodebuild Workaround +---@tag xcodebuild.xcodebuild-offline +---@brief [[ +--- +---This module provides a workaround for the issue with slow `xcodebuild` command. +--- +---The issue is caused by the fact that `xcodebuild` tries to connect to the Apple +---servers before building the project, which can take 20 seconds or more. +---Usually, those requests are not necessary, but they slow down each build. +--- +---This module provides a workaround by mapping Apple servers to localhost in the +---`/etc/hosts` file during the build. It is a temporary solution and should be +---used with caution. +--- +---Keep in mind that disabling access to `developerservices2.apple.com` for +---`xcodebuild` may cause some issues with the build process. It will disable +---things like registering devices, capabilities, and other network-related +---features. Therefore, it's best to use it when you are working just on the +---code and don't need updating project settings. +--- +---To enable this workaround, set `commands.run_xcodebuild_in_offline_mode` +---to `true` in the configuration. +--- +---👉 Passwordless access to `xcodebuild_offline` +--- +---This workaround requires `sudo` to update the `/etc/hosts` file. +---Make sure to use the command below, otherwise you may break your `sudo` command: +--- +--->bash +--- sudo visudo -f /etc/sudoers +---< +--- +---Append this line, but first update the path and the username: +--- +--->bash +--- YOUR_USERNAME ALL = (ALL) NOPASSWD: /Users/YOUR_USERNAME/.local/share/nvim/lazy/xcodebuild.nvim/tools/xcodebuild_offline +---< +--- +---👉 Creating a local copy of `xcodebuild_offline` +--- +---If you don't want to configure the passwordless permission to the file +---that could be changed in the future, you can make a local copy of this +---script, set your local path in the config `commands.xcodebuild_offline`, +---and update `/etc/sudoers` accordingly. +--- +---Please remember that you will have to update this file manually if it +---changes in the future. +--- +--- +--- +---More details about this issue can be found here: +--- https://github.com/wojciech-kulik/xcodebuild.nvim/issues/201#issuecomment-2423828065 +--- +---@brief ]] + +local appdata = require("xcodebuild.project.appdata") +local config = require("xcodebuild.core.config").options.commands +local notifications = require("xcodebuild.broadcasting.notifications") + +local M = {} + +---Returns the path to the wrapper script for `pymobiledevice3` tool. +---@return string +local function get_tool_path() + return config.xcodebuild_offline and vim.fn.expand(config.xcodebuild_offline) + or appdata.tool_path(appdata.XCODEBUILD_OFFLINE_TOOL) +end + +---Checks whether the `sudo` command has passwordless access to the tool. +---@return boolean +local function check_sudo() + local util = require("xcodebuild.util") + local path = get_tool_path() + local permissions = util.shell("sudo -l 2>/dev/null") + + for _, line in ipairs(permissions) do + if line:match("NOPASSWD.*" .. path) then + return true + end + end + + return false +end + +---Returns whether the `xcodebuild` command should be run in offline mode. +---@return boolean +function M.is_enabled() + return config.run_xcodebuild_in_offline_mode +end + +---Wraps the `xcodebuild` command with the workaround script if needed. +---@param command string +---@return string +function M.wrap_command_if_needed(command) + if not M.is_enabled() then + return command + end + + if not check_sudo() then + notifications.stop_build_timer() + error("xcodebuild.nvim: `xcodebuild_offline` requires passwordless access to the sudo command.") + end + + return "sudo '" .. get_tool_path() .. "' " .. command +end + +return M diff --git a/lua/xcodebuild/project/appdata.lua b/lua/xcodebuild/project/appdata.lua index f9edec4..2aa16e9 100644 --- a/lua/xcodebuild/project/appdata.lua +++ b/lua/xcodebuild/project/appdata.lua @@ -31,6 +31,7 @@ ---@field GETSNAPSHOTS_TOOL string # The name of the getsnapshots tool. ---@field PROJECT_HELPER_TOOL string # The name of the project helper tool. ---@field REMOTE_DEBUGGER_TOOL string # The name of the remote debugger tool. +---@field XCODEBUILD_OFFLINE_TOOL string # The name of the xcodebuild offline tool. local util = require("xcodebuild.util") @@ -65,6 +66,7 @@ M.breakpoints_filepath = M.appdir .. "/breakpoints.json" M.GETSNAPSHOTS_TOOL = "getsnapshots" M.PROJECT_HELPER_TOOL = "project_helper.rb" M.REMOTE_DEBUGGER_TOOL = "remote_debugger" +M.XCODEBUILD_OFFLINE_TOOL = "xcodebuild_offline" ---Returns the path to the tool with the given {name}. ---@param name string diff --git a/scripts/help-update.sh b/scripts/help-update.sh index bc88ad2..5177e6e 100755 --- a/scripts/help-update.sh +++ b/scripts/help-update.sh @@ -1,53 +1,54 @@ #!/bin/bash lemmy-help \ - --layout compact:0 \ - --indent 2 \ - -f -t -a -c \ - ./lua/xcodebuild/init.lua \ - ./lua/xcodebuild/docs/features.lua \ - ./lua/xcodebuild/docs/requirements.lua \ - ./lua/xcodebuild/docs/highlights.lua \ - ./lua/xcodebuild/docs/keybindings.lua \ - ./lua/xcodebuild/docs/commands.lua \ - ./lua/xcodebuild/docs/global_variables.lua \ - ./lua/xcodebuild/docs/ios17.lua \ - ./lua/xcodebuild/health.lua \ - ./lua/xcodebuild/actions.lua \ - ./lua/xcodebuild/core/constants.lua \ - ./lua/xcodebuild/core/autocmd.lua \ - ./lua/xcodebuild/core/config.lua \ - ./lua/xcodebuild/core/quickfix.lua \ - ./lua/xcodebuild/core/xcode.lua \ - ./lua/xcodebuild/xcode_logs/parser.lua \ - ./lua/xcodebuild/xcode_logs/panel.lua \ - ./lua/xcodebuild/project/config.lua \ - ./lua/xcodebuild/project/appdata.lua \ - ./lua/xcodebuild/project/builder.lua \ - ./lua/xcodebuild/project/manager.lua \ - ./lua/xcodebuild/platform/device.lua \ - ./lua/xcodebuild/platform/device_proxy.lua \ - ./lua/xcodebuild/platform/macos.lua \ - ./lua/xcodebuild/broadcasting/events.lua \ - ./lua/xcodebuild/broadcasting/notifications.lua \ - ./lua/xcodebuild/tests/diagnostics.lua \ - ./lua/xcodebuild/tests/enumeration_parser.lua \ - ./lua/xcodebuild/tests/explorer.lua \ - ./lua/xcodebuild/tests/provider.lua \ - ./lua/xcodebuild/tests/runner.lua \ - ./lua/xcodebuild/tests/search.lua \ - ./lua/xcodebuild/tests/snapshots.lua \ - ./lua/xcodebuild/code_coverage/coverage.lua \ - ./lua/xcodebuild/code_coverage/report.lua \ - ./lua/xcodebuild/integrations/dap.lua \ - ./lua/xcodebuild/integrations/remote_debugger.lua \ - ./lua/xcodebuild/integrations/lsp.lua \ - ./lua/xcodebuild/integrations/nvim-tree.lua \ - ./lua/xcodebuild/integrations/neo-tree.lua \ - ./lua/xcodebuild/integrations/oil-nvim.lua \ - ./lua/xcodebuild/integrations/quick.lua \ - ./lua/xcodebuild/integrations/xcode-build-server.lua \ - ./lua/xcodebuild/ui/pickers.lua \ - ./lua/xcodebuild/helpers.lua \ - ./lua/xcodebuild/util.lua \ - > doc/xcodebuild.txt + --layout compact:0 \ + --indent 2 \ + -f -t -a -c \ + ./lua/xcodebuild/init.lua \ + ./lua/xcodebuild/docs/features.lua \ + ./lua/xcodebuild/docs/requirements.lua \ + ./lua/xcodebuild/docs/highlights.lua \ + ./lua/xcodebuild/docs/keybindings.lua \ + ./lua/xcodebuild/docs/commands.lua \ + ./lua/xcodebuild/docs/global_variables.lua \ + ./lua/xcodebuild/docs/ios17.lua \ + ./lua/xcodebuild/health.lua \ + ./lua/xcodebuild/actions.lua \ + ./lua/xcodebuild/core/constants.lua \ + ./lua/xcodebuild/core/autocmd.lua \ + ./lua/xcodebuild/core/config.lua \ + ./lua/xcodebuild/core/quickfix.lua \ + ./lua/xcodebuild/core/xcode.lua \ + ./lua/xcodebuild/xcode_logs/parser.lua \ + ./lua/xcodebuild/xcode_logs/panel.lua \ + ./lua/xcodebuild/project/config.lua \ + ./lua/xcodebuild/project/appdata.lua \ + ./lua/xcodebuild/project/builder.lua \ + ./lua/xcodebuild/project/manager.lua \ + ./lua/xcodebuild/platform/device.lua \ + ./lua/xcodebuild/platform/device_proxy.lua \ + ./lua/xcodebuild/platform/macos.lua \ + ./lua/xcodebuild/broadcasting/events.lua \ + ./lua/xcodebuild/broadcasting/notifications.lua \ + ./lua/xcodebuild/tests/diagnostics.lua \ + ./lua/xcodebuild/tests/enumeration_parser.lua \ + ./lua/xcodebuild/tests/explorer.lua \ + ./lua/xcodebuild/tests/provider.lua \ + ./lua/xcodebuild/tests/runner.lua \ + ./lua/xcodebuild/tests/search.lua \ + ./lua/xcodebuild/tests/snapshots.lua \ + ./lua/xcodebuild/code_coverage/coverage.lua \ + ./lua/xcodebuild/code_coverage/report.lua \ + ./lua/xcodebuild/integrations/dap.lua \ + ./lua/xcodebuild/integrations/remote_debugger.lua \ + ./lua/xcodebuild/integrations/lsp.lua \ + ./lua/xcodebuild/integrations/nvim-tree.lua \ + ./lua/xcodebuild/integrations/neo-tree.lua \ + ./lua/xcodebuild/integrations/oil-nvim.lua \ + ./lua/xcodebuild/integrations/quick.lua \ + ./lua/xcodebuild/integrations/xcode-build-server.lua \ + ./lua/xcodebuild/integrations/xcodebuild-offline.lua \ + ./lua/xcodebuild/ui/pickers.lua \ + ./lua/xcodebuild/helpers.lua \ + ./lua/xcodebuild/util.lua \ + >doc/xcodebuild.txt diff --git a/tools/xcodebuild_offline b/tools/xcodebuild_offline new file mode 100755 index 0000000..2c5db4b --- /dev/null +++ b/tools/xcodebuild_offline @@ -0,0 +1,38 @@ +#!/bin/bash + +### Author: Rudrank Riyam (github.com/rudrankriyam) +### Source: https://x.com/rudrankriyam/status/1847734299740811675 (with minor modifications) + +# Function to block the domain +block_domain() { + echo "127.0.0.1 developerservices2.apple.com" | sudo tee -a /etc/hosts &>/dev/null +} + +# Function to unblock the domain +unblock_domain() { + sudo sed -i '' '/developerservices2\.apple\.com/d' /etc/hosts +} + +# Check if xcodebuild command is provided +if [ $# -eq 0 ]; then + echo "Please provide the xcodebuild command as arguments" + exit 1 +fi + +# Block the domain +block_domain + +# Unblock the domain on exit (even if killed) +trap unblock_domain EXIT + +# Run xcodebuild with all passed arguments +sudo -u $SUDO_USER "$@" + +# Capture the exit code of xcodebuild +BUILD_RESULT=$? + +# Unblock the domain +unblock_domain + +# Exit with the same code as xcodebuild +exit $BUILD_RESULT