From: Steph Burckel Date: Sun, 11 Jul 2021 21:28:35 +0000 (-0400) Subject: Changes to accomodate moving to Git and to compiling on macOS 10.11 X-Git-Url: http://www.privoxy.org/gitweb/%22https:/developer-manual/faq/user-manual/static/@user-manual@@actions-help-prefix@HIDE-CONTENT-DISPOSITION?a=commitdiff_plain;h=3ddeb888a0cee8e8ffd90767af5463aaa184bea9;p=OSXPackageBuilder.git Changes to accomodate moving to Git and to compiling on macOS 10.11 /bin/bash: q: command not found --- diff --git a/OS X 10.6+ PCRE.pkgproj b/OS X 10.6+ PCRE.pkgproj index 77b9821..327541d 100755 --- a/OS X 10.6+ PCRE.pkgproj +++ b/OS X 10.6+ PCRE.pkgproj @@ -5,6 +5,10 @@ PACKAGES + MUST-CLOSE-APPLICATION-ITEMS + + MUST-CLOSE-APPLICATIONS + PACKAGE_FILES DEFAULT_INSTALL_LOCATION @@ -349,7 +353,7 @@ PATH_TYPE 0 PERMISSIONS - 493 + 1005 TYPE 1 UID @@ -812,9 +816,9 @@ GID 0 PATH - pkg content/usr/local/etc/privoxy/vanilla/templates/client-tags + /Users/steph/code/OSXPackageBuilder/pkg content/usr/local/etc/privoxy/vanilla/templates/client-tags PATH_TYPE - 1 + 0 PERMISSIONS 420 TYPE @@ -918,6 +922,22 @@ UID 0 + + CHILDREN + + GID + 0 + PATH + /Users/steph/code/OSXPackageBuilder/pkg content/usr/local/etc/privoxy/vanilla/templates/edit-actions-for-url-string-filter + PATH_TYPE + 0 + PERMISSIONS + 420 + TYPE + 3 + UID + 0 + CHILDREN @@ -1190,22 +1210,6 @@ UID 0 - - CHILDREN - - GID - 0 - PATH - pkg content/usr/local/etc/privoxy/vanilla/templates/show-version - PATH_TYPE - 1 - PERMISSIONS - 420 - TYPE - 3 - UID - 0 - CHILDREN @@ -1698,7 +1702,7 @@ GID 0 PATH - pkg content/usr/local/share/doc/privoxy/developer-manual/cvs.html + pkg content/usr/local/share/doc/privoxy/developer-manual/documentation.html PATH_TYPE 1 PERMISSIONS @@ -1714,9 +1718,9 @@ GID 0 PATH - pkg content/usr/local/share/doc/privoxy/developer-manual/documentation.html + /Users/steph/code/OSXPackageBuilder/pkg content/usr/local/share/doc/privoxy/developer-manual/git.html PATH_TYPE - 1 + 0 PERMISSIONS 420 TYPE @@ -1972,25 +1976,9 @@ GID 0 PATH - pkg content/usr/local/share/doc/privoxy/images/files-in-use.jpg + /Users/steph/code/OSXPackageBuilder/pkg content/usr/local/share/doc/privoxy/images/privoxy.png PATH_TYPE - 1 - PERMISSIONS - 420 - TYPE - 3 - UID 0 - - - CHILDREN - - GID - 0 - PATH - pkg content/usr/local/share/doc/privoxy/images/proxy_setup.jpg - PATH_TYPE - 1 PERMISSIONS 420 TYPE @@ -2823,9 +2811,9 @@ GID 0 PATH - pkg content/usr/local/share/man/man1/privoxy.1 + /Users/steph/code/OSXPackageBuilder/pkg content/usr/local/share/man/man1/privoxy.8 PATH_TYPE - 1 + 0 PERMISSIONS 420 TYPE @@ -2919,8 +2907,16 @@ PAYLOAD_TYPE 0 + PRESERVE_EXTENDED_ATTRIBUTES + + SHOW_INVISIBLE + + SPLIT_FORKS + + TREAT_MISSING_FILES_AS_WARNING + VERSION - 4 + 5 PACKAGE_SCRIPTS @@ -2947,15 +2943,29 @@ 1 CONCLUSION_ACTION 0 + FOLLOW_SYMBOLIC_LINKS + IDENTIFIER org.ijbswa.privoxy + LOCATION + 0 NAME OS X 10.6+ PCRE OVERWRITE_PERMISSIONS + PAYLOAD_SIZE + -1 + REFERENCE_PATH + + RELOCATABLE + + USE_HFS+_COMPRESSION + VERSION - 3.0.26 + 3.0.32 + TYPE + 0 UUID C4212B54-A4A8-48AF-8C06-5D4AAE91C4FF @@ -2981,6 +2991,18 @@ PROJECT_PRESENTATION + BACKGROUND + + APPAREANCES + + DARK_AQUA + + LIGHT_AQUA + + + SHARED_SETTINGS_FOR_ALL_APPAREANCES + + INSTALLATION TYPE HIERARCHIES @@ -2990,6 +3012,8 @@ LIST + CHILDREN + DESCRIPTION @@ -3028,6 +3052,8 @@ This release includes a bundled copy of PCRE 8.21. IC_REQUIREMENT_CPU_POWERPC_ARCHITECTURE_TYPE 0 + IC_REQUIREMENT_CHECK_TYPE + -1 IDENTIFIER fr.whitebox.Packages.requirement.cpu MESSAGE @@ -3049,6 +3075,8 @@ This release includes a bundled copy of PCRE 8.21. IC_REQUIREMENT_OS_MINIMUM_VERSION 100500 + IC_REQUIREMENT_CHECK_TYPE + -1 IDENTIFIER fr.whitebox.Packages.requirement.os MESSAGE @@ -3068,8 +3096,6 @@ This release includes a bundled copy of PCRE 8.21. Privoxy for OS X 10.6 and higher - TOOLTIP - TYPE 0 UUID @@ -3080,8 +3106,6 @@ This release includes a bundled copy of PCRE 8.21. - INSTALLATION TYPE - 0 MODE 1 @@ -3154,7 +3178,7 @@ This release includes a bundled copy of PCRE 8.21. VALUE PATH - /Users/yan/code/Privoxy/OSXPackageBuilder/pkg resources/interface texts/Introduction.txt + /Users/steph/code/OSXPackageBuilder/pkg resources/interface texts/Introduction.txt PATH_TYPE 0 @@ -3163,8 +3187,6 @@ This release includes a bundled copy of PCRE 8.21. LICENSE - KEYWORDS - LOCALIZATIONS @@ -3173,7 +3195,7 @@ This release includes a bundled copy of PCRE 8.21. VALUE PATH - /Users/yan/code/Privoxy/OSXPackageBuilder/pkg resources/interface texts/LICENSE.txt + /Users/steph/code/OSXPackageBuilder/pkg resources/interface texts/LICENSE.txt PATH_TYPE 0 @@ -3192,7 +3214,7 @@ This release includes a bundled copy of PCRE 8.21. VALUE PATH - /Users/yan/code/Privoxy/OSXPackageBuilder/pkg resources/interface texts/ReadMe64.txt + /Users/steph/code/OSXPackageBuilder/pkg resources/interface texts/ReadMe64.txt PATH_TYPE 0 @@ -3209,7 +3231,7 @@ This release includes a bundled copy of PCRE 8.21. VALUE PATH - /Users/yan/code/Privoxy/OSXPackageBuilder/pkg resources/interface texts/Finish Up.txt + /Users/steph/code/OSXPackageBuilder/pkg resources/interface texts/Finish Up.txt PATH_TYPE 0 @@ -3300,19 +3322,13 @@ This release includes a bundled copy of PCRE 8.21. - POSTINSTALL_PATH - - PREINSTALL_PATH - RESOURCES ROOT_VOLUME_ONLY - + PROJECT_SETTINGS - ADVANCED_OPTIONS - BUILD_FORMAT 0 BUILD_PATH @@ -3492,6 +3508,10 @@ This release includes a bundled copy of PCRE 8.21. NAME Privoxy 3.0.26 64 bit + PAYLOAD_ONLY + + TREAT_MISSING_PRESENTATION_DOCUMENTS_AS_WARNING + TYPE diff --git a/OS X Package Builder HOWTO.txt b/OS X Package Builder HOWTO.txt index 147abc2..4707761 100644 --- a/OS X Package Builder HOWTO.txt +++ b/OS X Package Builder HOWTO.txt @@ -5,13 +5,11 @@ This document will guide you through the complete process necessary to create a ASSUMPTIONS -1. That the Privoxy CVS project is available in a folder parallel to the one containing this file. -- If building for release it MUST have been exported from Sourceforge to a folder named 'dist', pinned at whichever release you intend to build (as per the instructions in the Privoxy developer manual) -- If doing a general test build, you might have simply checked out the head of the CVS project to a folder named 'current'. -- If you are using a folder name other than these two (or else both exist) you will be prompted to enter the source folder you wish to use when running the scripts detailed below. +1. That the Privoxy Git project is available in a folder parallel to the one containing this file. +- If building for release it MUST have been checked out from Git at whichever release tag you intend to build (as per the instructions in the Privoxy developer manual, i.e. git checkout v_X_Y_Z) 2. That you have Xcode installed, including the SDKs for each OS X version you intend your package(s) to support. -3. That your build machine runs Snow Leopard (OS X 10.6). It will likely work equally well on Leopard or Lion (or later), but PackageMaker is substantially different in Tiger and earlier versions of OS X (even the project file format is different). -4. All references to files and folders in this document should be assumed to be within the OSXBuildSystem folder unless stated otherwise. +3. That your build machine runs Snow Leopard (OS X 10.6) or a more recent release. PackageMaker is substantially different in Tiger and earlier versions of OS X (even the project file format is different). +4. All references to files and folders in this document should be assumed to be within the OSXPackageBuilder folder unless stated otherwise. OVERVIEW OF STEPS @@ -39,9 +37,9 @@ which will build a Universal binary containing targets for PPC, i386 and x86_64 The most common usage therefore would be as follows: -./build.sh snowleopardx64 -pcre +./build.sh current -pcre -which will build a binary targetting only x86_64 processors (note that OS X has supported only x86_64 since Snow Leopard). +which will build a binary targeting only x86_64 processors (note that OS X has supported only x86_64 since Snow Leopard). Running build.sh without supplying any parameters will cause it to list all the possible options, should you have an alternative target requirement. @@ -65,7 +63,7 @@ A sample command line that will build Privoxy with external PCRE to run on Snow This example assumes that a valid build of PCRE supporting x86_64 processors and a minimum OS X version of 10.6 is present in /usr/local/lib. -1.2 Builds for the Sourceforge Privoxy project release set +1.2 Builds for the Privoxy project release set Three packages are built for this target release set: diff --git a/build.sh b/build.sh index d7b12dd..2f00841 100755 --- a/build.sh +++ b/build.sh @@ -5,7 +5,7 @@ # Purpose : Build the privoxy binary, documentation and config files # for the chosen target environment # -# Copyright : Written by and Copyright (C) 2001-2012 the +# Copyright : Written by and Copyright (C) 2001-2021 the # Privoxy team. http://www.privoxy.org/ # # This program is free software; you can redistribute it @@ -36,7 +36,7 @@ # must provide target # if [ $# -eq 0 -o $# -gt 2 ]; then - echo "Usage: $0 lion | snowleopardx64 | snowleopard | snowleopardi386 | leopardupwards | leopard | leopardi386 | leopardppc | tiger | tigeri386 | tigerppc | panther [-pcre]" + echo "Usage: $0 current | lion | snowleopardx64 | snowleopard | snowleopardi386 | leopardupwards | leopard | leopardi386 | leopardppc | tiger | tigeri386 | tigerppc | panther [-pcre]" exit 1 fi @@ -44,6 +44,8 @@ fi # load common settings # . ./common.sh $1 +#echo "${XCODE_PATH}" +#echo ${SYSROOT} # # must have Xcode diff --git a/common.sh b/common.sh index 74dcfdc..c78f749 100755 --- a/common.sh +++ b/common.sh @@ -5,7 +5,7 @@ # Purpose : Establish settings common to the build and privoxy-create # scripts. # -# Copyright : Written by and Copyright (C) 2001-2012 the +# Copyright : Written by and Copyright (C) 2001-2021 the # Privoxy team. http://www.privoxy.org/ # # This program is free software; you can redistribute it @@ -47,6 +47,15 @@ release_name=$1 # NOTE: SYSROOT ought to be programmatically determined using XCODE_PATH, however since upgrading my build environment to El Capitan xcode-select returns a non-useful path, hence I am forced to set the SYSROOT explicitly for my build environment, which is now a hybrid of XCode 3.2.6 'running' on OS X 10.11. I am not going to risk upgrading XCode for fear of losing the ability to target down-level OS X versions. # case "${release_name}" in + # Mac OS X 10.11 (x86_64 only) + "current") + XCODE_PATH="`/usr/bin/xcode-select -print-path`" + SYSROOT="-isysroot ${XCODE_PATH}/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk" + MACOSX_VERSION="-mmacosx-version-min=10.6" + ARCH="-arch x86_64" + STARTUP="LaunchDaemon" + CFLAGS="-mtune=x86_64 ${CFLAGS}" + ;; # Mac OS X 10.7 (x86_64 only) "lion") XCODE_PATH="`/usr/bin/xcode-select -print-path`" @@ -233,7 +242,7 @@ case "${DIRS_FOUND}" in ;; # either both or neither found 11|0) - read -p 'Could not select the Privoxy source directory. Please supply the directory name (e.g. current or dist): ' SOURCE_DIR + read -p 'Could not select the Privoxy source directory (it should be in a directory parallel to that containing this build script). Please supply the directory name (e.g. current or dist): ' SOURCE_DIR ;; esac cd OSXPackageBuilder diff --git a/constructPkgContent.sh b/constructPkgContent.sh index ff6b617..30d93fb 100755 --- a/constructPkgContent.sh +++ b/constructPkgContent.sh @@ -51,6 +51,7 @@ echo "" echo "" echo "Copy the compiled privoxy binary from the '${SOURCE_DIR}' directory" echo "" +mkdir -vp pkg\ content/usr/local/sbin cp -v ../${SOURCE_DIR}/privoxy pkg\ content/usr/local/sbin # Copy the configuration hierarchy from the '${SOURCE_DIR}' directory @@ -58,6 +59,7 @@ echo "" echo "" echo "Copy most of the configuration hierarchy from the '${SOURCE_DIR}' directory" echo "" +mkdir -vp pkg\ content/usr/local/etc/privoxy/vanilla for i in default.action default.filter match-all.action trust user.action user.filter templates; do if [ "$i" = "templates" ]; then # for the templates subfolder copy all files therein @@ -83,6 +85,7 @@ echo "" echo "" echo "Copy the documentation hierarchy from the '${SOURCE_DIR}' directory" echo "" +mkdir -vp pkg\ content/usr/local/share/doc/privoxy # copy the required directory hierarchies for i in developer-manual faq images man-page team user-manual; do cp -vR ../${SOURCE_DIR}/doc/webserver/$i pkg\ content/usr/local/share/doc/privoxy/$i @@ -103,7 +106,8 @@ echo "" echo "" echo "Copy the manpage from the '${SOURCE_DIR}' directory" echo "" -cp -v ../${SOURCE_DIR}/privoxy.1 pkg\ content/usr/local/share/man/man1 +mkdir -vp pkg\ content/usr/local/share/man/man1 +cp -v ../${SOURCE_DIR}/privoxy.8 pkg\ content/usr/local/share/man/man1 # Optionally copy the PCRE libraries if [ "$1" == "-pcre" ]; then