aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMicah Lee <micah@micahflee.com>2021-12-23 11:58:31 -0800
committerMicah Lee <micah@micahflee.com>2021-12-23 11:58:31 -0800
commitb5cac769bb53c38bffb5cda1f4bc1257121a8f9c (patch)
tree8ad64961e5f69b2b7cdffbe16d12109f294f1b60
parent159540f06b3cf4697bb7defac5610275aa5618ff (diff)
parent07665a01090c63dc93becb6e89d6d0719cc59981 (diff)
downloadonionshare-b5cac769bb53c38bffb5cda1f4bc1257121a8f9c.tar.gz
onionshare-b5cac769bb53c38bffb5cda1f4bc1257121a8f9c.zip
Merge branch 'cx_freeze-packaging' of github.com:micahflee/onionshare into cx_freeze-packaging
-rw-r--r--cli/README.md8
-rw-r--r--desktop/README.md6
-rw-r--r--desktop/package/build-windows.py296
-rw-r--r--desktop/setup-freeze.py8
4 files changed, 304 insertions, 14 deletions
diff --git a/cli/README.md b/cli/README.md
index bfc287be..12a157e3 100644
--- a/cli/README.md
+++ b/cli/README.md
@@ -97,11 +97,3 @@ To run tests:
```sh
poetry run pytest -v ./tests
```
-
-## Build a wheel package
-
-```sh
-poetry build
-```
-
-This will create `dist/onionshare_cli-$VERSION-py3-none-any.whl`.
diff --git a/desktop/README.md b/desktop/README.md
index 92412146..1578f956 100644
--- a/desktop/README.md
+++ b/desktop/README.md
@@ -70,6 +70,12 @@ poetry run onionshare -v
poetry run onionshare -v --local-only
```
+You can also run `onionshare-cli` from the source tree, and it will look for Tor binaries in `desktop/onionshare/resources/tor`.
+
+```sh
+poetry run onionshare-cli --help
+```
+
## Running tests
Run the tests:
diff --git a/desktop/package/build-windows.py b/desktop/package/build-windows.py
new file mode 100644
index 00000000..045b5a2d
--- /dev/null
+++ b/desktop/package/build-windows.py
@@ -0,0 +1,296 @@
+#!/usr/bin/env python3
+import os
+import inspect
+import subprocess
+import shutil
+
+
+root = os.path.dirname(
+ os.path.dirname(
+ os.path.dirname(os.path.abspath(inspect.getfile(inspect.currentframe())))
+ )
+)
+
+
+def run(cmd, cwd=None):
+ print(cmd)
+ subprocess.run(cmd, cwd=cwd, check=True)
+
+
+def get_size(dir):
+ size = 0
+ for path, dirs, files in os.walk(dir):
+ for f in files:
+ fp = os.path.join(path, f)
+ size += os.path.getsize(fp)
+ return size
+
+
+def main():
+ desktop_dir = os.path.join(root, "desktop")
+
+ print("○ Clean up from last build")
+ if os.path.exists(os.path.join(desktop_dir, "build")):
+ shutil.rmtree(os.path.join(desktop_dir, "build"))
+
+ print("○ Building binaires")
+ run(
+ [
+ shutil.which("python"),
+ "setup-freeze.py",
+ "build",
+ ],
+ desktop_dir,
+ )
+ before_size = get_size(os.path.join(desktop_dir, "build", "exe.win32-3.9"))
+
+ print("○ Delete unused PySide2 stuff to save space")
+ for dirname in ["examples", "qml"]:
+ shutil.rmtree(
+ os.path.join(
+ desktop_dir, "build", "exe.win32-3.9", "lib", "PySide2", dirname
+ )
+ )
+ for filename in [
+ "lconvert.exe",
+ "linguist.exe",
+ "lrelease.exe",
+ "lupdate.exe",
+ "plugins/assetimporters/assimp.dll",
+ "plugins/assetimporters/uip.dll",
+ "plugins/audio/qtaudio_wasapi.dll",
+ "plugins/audio/qtaudio_windows.dll",
+ "plugins/bearer/qgenericbearer.dll",
+ "plugins/canbus/qtpassthrucanbus.dll",
+ "plugins/canbus/qtpeakcanbus.dll",
+ "plugins/canbus/qtsysteccanbus.dll",
+ "plugins/canbus/qttinycanbus.dll",
+ "plugins/canbus/qtvectorcanbus.dll",
+ "plugins/canbus/qtvirtualcanbus.dll",
+ "plugins/gamepads/xinputgamepad.dll",
+ "plugins/generic/qtuiotouchplugin.dll",
+ "plugins/geometryloaders/defaultgeometryloader.dll",
+ "plugins/geometryloaders/gltfgeometryloader.dll",
+ "plugins/geoservices/qtgeoservices_esri.dll",
+ "plugins/geoservices/qtgeoservices_itemsoverlay.dll",
+ "plugins/geoservices/qtgeoservices_mapbox.dll",
+ "plugins/geoservices/qtgeoservices_nokia.dll",
+ "plugins/geoservices/qtgeoservices_osm.dll",
+ "plugins/mediaservice/dsengine.dll",
+ "plugins/mediaservice/qtmedia_audioengine.dll",
+ "plugins/mediaservice/wmfengine.dll",
+ "plugins/platforminputcontexts/qtvirtualkeyboardplugin.dll",
+ "plugins/platforms/qdirect2d.dll",
+ "plugins/platforms/qoffscreen.dll",
+ "plugins/platforms/qwebgl.dll",
+ "plugins/platformthemes/qxdgdesktopportal.dll",
+ "plugins/playlistformats/qtmultimedia_m3u.dll",
+ "plugins/position/qtposition_positionpoll.dll",
+ "plugins/position/qtposition_serialnmea.dll",
+ "plugins/position/qtposition_winrt.dll",
+ "plugins/printsupport/windowsprintersupport.dll",
+ "plugins/qmltooling/qmldbg_debugger.dll",
+ "plugins/qmltooling/qmldbg_inspector.dll",
+ "plugins/qmltooling/qmldbg_local.dll",
+ "plugins/qmltooling/qmldbg_messages.dll",
+ "plugins/qmltooling/qmldbg_native.dll",
+ "plugins/qmltooling/qmldbg_nativedebugger.dll",
+ "plugins/qmltooling/qmldbg_preview.dll",
+ "plugins/qmltooling/qmldbg_profiler.dll",
+ "plugins/qmltooling/qmldbg_quickprofiler.dll",
+ "plugins/qmltooling/qmldbg_server.dll",
+ "plugins/qmltooling/qmldbg_tcp.dll",
+ "plugins/renderers/openglrenderer.dll",
+ "plugins/renderplugins/scene2d.dll",
+ "plugins/scenegraph/qsgd3d12backend.dll",
+ "plugins/sceneparsers/gltfsceneexport.dll",
+ "plugins/sceneparsers/gltfsceneimport.dll",
+ "plugins/sensorgestures/qtsensorgestures_plugin.dll",
+ "plugins/sensorgestures/qtsensorgestures_shakeplugin.dll",
+ "plugins/sensors/qtsensors_generic.dll",
+ "plugins/sqldrivers/qsqlite.dll",
+ "plugins/sqldrivers/qsqlodbc.dll",
+ "plugins/sqldrivers/qsqlpsql.dll",
+ "plugins/styles/qwindowsvistastyle.dll",
+ "plugins/texttospeech/qtexttospeech_sapi.dll",
+ "plugins/virtualkeyboard/qtvirtualkeyboard_hangul.dll",
+ "plugins/virtualkeyboard/qtvirtualkeyboard_openwnn.dll",
+ "plugins/virtualkeyboard/qtvirtualkeyboard_pinyin.dll",
+ "plugins/virtualkeyboard/qtvirtualkeyboard_tcime.dll",
+ "plugins/virtualkeyboard/qtvirtualkeyboard_thai.dll",
+ "plugins/webview/qtwebview_webengine.dll",
+ "pyside2-lupdate.exe",
+ "Qt3DAnimation.pyd",
+ "Qt3DAnimation.pyi",
+ "Qt3DCore.pyd",
+ "Qt3DCore.pyi",
+ "Qt3DExtras.pyd",
+ "Qt3DExtras.pyi",
+ "Qt3DInput.pyd",
+ "Qt3DInput.pyi",
+ "Qt3DLogic.pyd",
+ "Qt3DLogic.pyi",
+ "Qt3DRender.pyd",
+ "Qt3DRender.pyi",
+ "Qt53DAnimation.dll",
+ "Qt53DCore.dll",
+ "Qt53DExtras.dll",
+ "Qt53DInput.dll",
+ "Qt53DLogic.dll",
+ "Qt53DQuick.dll",
+ "Qt53DQuickAnimation.dll",
+ "Qt53DQuickExtras.dll",
+ "Qt53DQuickInput.dll",
+ "Qt53DQuickRender.dll",
+ "Qt53DQuickScene2D.dll",
+ "Qt53DRender.dll",
+ "Qt5Bluetooth.dll",
+ "Qt5Bodymovin.dll",
+ "Qt5Charts.dll",
+ "Qt5Concurrent.dll",
+ "Qt5DataVisualization.dll",
+ "Qt5DBus.dll",
+ "Qt5Designer.dll",
+ "Qt5DesignerComponents.dll",
+ "Qt5Gamepad.dll",
+ "Qt5Help.dll",
+ "Qt5Location.dll",
+ "Qt5Multimedia.dll",
+ "Qt5MultimediaQuick.dll",
+ "Qt5MultimediaWidgets.dll",
+ "Qt5Nfc.dll",
+ "Qt5OpenGL.dll",
+ "Qt5Pdf.dll",
+ "Qt5PdfWidgets.dll",
+ "Qt5Positioning.dll",
+ "Qt5PositioningQuick.dll",
+ "Qt5PrintSupport.dll",
+ "Qt5Purchasing.dll",
+ "Qt5Quick.dll",
+ "Qt5Quick3D.dll",
+ "Qt5Quick3DAssetImport.dll",
+ "Qt5Quick3DRender.dll",
+ "Qt5Quick3DRuntimeRender.dll",
+ "Qt5Quick3DUtils.dll",
+ "Qt5QuickControls2.dll",
+ "Qt5QuickParticles.dll",
+ "Qt5QuickShapes.dll",
+ "Qt5QuickTemplates2.dll",
+ "Qt5QuickTest.dll",
+ "Qt5QuickWidgets.dll",
+ "Qt5RemoteObjects.dll",
+ "Qt5Script.dll",
+ "Qt5ScriptTools.dll",
+ "Qt5Scxml.dll",
+ "Qt5Sensors.dll",
+ "Qt5SerialBus.dll",
+ "Qt5SerialPort.dll",
+ "Qt5Sql.dll",
+ "Qt5Svg.dll",
+ "Qt5Test.dll",
+ "Qt5TextToSpeech.dll",
+ "Qt5VirtualKeyboard.dll",
+ "Qt5WebChannel.dll",
+ "Qt5WebEngine.dll",
+ "Qt5WebEngineCore.dll",
+ "Qt5WebEngineWidgets.dll",
+ "Qt5WebSockets.dll",
+ "Qt5WebView.dll",
+ "Qt5Xml.dll",
+ "Qt5XmlPatterns.dll",
+ "QtAxContainer.pyd",
+ "QtAxContainer.pyi",
+ "QtCharts.pyd",
+ "QtCharts.pyi",
+ "QtConcurrent.pyd",
+ "QtConcurrent.pyi",
+ "QtDataVisualization.pyd",
+ "QtDataVisualization.pyi",
+ "qtdiag.exe",
+ "QtHelp.pyd",
+ "QtHelp.pyi",
+ "QtLocation.pyd",
+ "QtLocation.pyi",
+ "QtMultimedia.pyd",
+ "QtMultimedia.pyi",
+ "QtMultimediaWidgets.pyd",
+ "QtMultimediaWidgets.pyi",
+ "QtNetwork.pyd",
+ "QtNetwork.pyi",
+ "QtOpenGL.pyd",
+ "QtOpenGL.pyi",
+ "QtOpenGLFunctions.pyd",
+ "QtOpenGLFunctions.pyi",
+ "QtPositioning.pyd",
+ "QtPositioning.pyi",
+ "QtPrintSupport.pyd",
+ "QtPrintSupport.pyi",
+ "QtQml.pyd",
+ "QtQml.pyi",
+ "QtQuick.pyd",
+ "QtQuick.pyi",
+ "QtQuickControls2.pyd",
+ "QtQuickControls2.pyi",
+ "QtQuickWidgets.pyd",
+ "QtQuickWidgets.pyi",
+ "QtRemoteObjects.pyd",
+ "QtRemoteObjects.pyi",
+ "QtScript.pyd",
+ "QtScript.pyi",
+ "QtScriptTools.pyd",
+ "QtScriptTools.pyi",
+ "QtScxml.pyd",
+ "QtScxml.pyi",
+ "QtSensors.pyd",
+ "QtSensors.pyi",
+ "QtSerialPort.pyd",
+ "QtSerialPort.pyi",
+ "QtSql.pyd",
+ "QtSql.pyi",
+ "QtSvg.pyd",
+ "QtSvg.pyi",
+ "QtTest.pyd",
+ "QtTest.pyi",
+ "QtTextToSpeech.pyd",
+ "QtTextToSpeech.pyi",
+ "QtUiTools.pyd",
+ "QtUiTools.pyi",
+ "QtWebChannel.pyd",
+ "QtWebChannel.pyi",
+ "QtWebEngine.pyd",
+ "QtWebEngine.pyi",
+ "QtWebEngineCore.pyd",
+ "QtWebEngineCore.pyi",
+ "QtWebEngineProcess.exe",
+ "QtWebEngineWidgets.pyd",
+ "QtWebEngineWidgets.pyi",
+ "QtWebSockets.pyd",
+ "QtWebSockets.pyi",
+ "QtWinExtras.pyd",
+ "QtWinExtras.pyi",
+ "QtXml.pyd",
+ "QtXml.pyi",
+ "QtXmlPatterns.pyd",
+ "QtXmlPatterns.pyi",
+ "rcc.exe",
+ "uic.exe",
+ ]:
+ os.remove(
+ os.path.join(
+ desktop_dir,
+ "build",
+ "exe.win32-3.9",
+ "lib",
+ "PySide2",
+ filename.replace("/", "\\"),
+ )
+ )
+
+ after_size = get_size(os.path.join(desktop_dir, "build", "exe.win32-3.9"))
+ freed_bytes = before_size - after_size
+ freed_mb = freed_bytes / 1024 / 1024
+ print(f"○ Freed {freed_mb} mb")
+
+
+if __name__ == "__main__":
+ main()
diff --git a/desktop/setup-freeze.py b/desktop/setup-freeze.py
index 5dc1728f..b264af80 100644
--- a/desktop/setup-freeze.py
+++ b/desktop/setup-freeze.py
@@ -114,7 +114,8 @@ include_files = [(os.path.join("..", "LICENSE"), "LICENSE")]
if platform.system() == "Windows":
include_msvcr = True
- gui_base = "Win32GUI"
+ # gui_base = "Win32GUI"
+ gui_base = None
exec_icon = os.path.join("onionshare", "resources", "onionshare.ico")
elif platform.system() == "Darwin":
@@ -219,11 +220,6 @@ setup(
"codesign_entitlements": os.path.join("package", "Entitlements.plist"),
"codesign_deep": True,
},
- # bdist_dmg, packaging the macOS app bundle in a dmg
- "bdist_dmg": {
- "volume_label": f"OnionShare-{version}",
- "applications_shortcut": True,
- },
},
executables=[
Executable(