Skip to content

813ethan/aseprite-termux

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 

Repository files navigation

aseprite-termux

This guide will show you how to build the animated sprite and pixel art tool aseprite for termux-x11.

The building process requires around 8GB of empty storage.

NOTE: Android 8 or higher is required in order to build and run aseprite (pthread_getname_np is needed and only available after Android 8)

repo branches used in this guide:

Steps

  1. install essential packages for compilation
pkg install x11-repo
pkg install build-essential binutils-is-llvm gn libglvnd* libsm libx11 libxcursor libxi python xdg-utils xorgproto
  1. clone skia and aseperite
cd $HOME
git clone --recursive https://github.com/aseprite/aseprite.git
mkdir $HOME/deps
cd $HOME/deps
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git
git clone -b aseprite-m102 https://github.com/aseprite/skia.git
cd skia
python tools/git-sync-deps
  1. apply patches required to build

aseprite/third_party/libwebp/CMakeLists.txt

--- aseprite/third_party/libwebp/CMakeLists.txt-old  2024-11-12 07:52:13.306967153 +1100
+++ aseprite/third_party/libwebp/CMakeLists.txt      2024-11-11 08:03:56.817791250 +1100
@@ -100,16 +100,16 @@
 # ##############################################################################
 # Android only.
 if(ANDROID)
-  include_directories(${ANDROID_NDK}/sources/android/cpufeatures)
-  add_library(cpufeatures STATIC
-              ${ANDROID_NDK}/sources/android/cpufeatures/cpu-features.c)
-  list(APPEND INSTALLED_LIBRARIES cpufeatures)
-  target_link_libraries(cpufeatures dl)
-  set(WEBP_DEP_LIBRARIES ${WEBP_DEP_LIBRARIES} cpufeatures)
-  set(WEBP_DEP_INCLUDE_DIRS ${WEBP_DEP_INCLUDE_DIRS}
-      ${ANDROID_NDK}/sources/android/cpufeatures)
-  add_definitions(-DHAVE_CPU_FEATURES_H=1)
-  set(HAVE_CPU_FEATURES_H 1)
+#  include_directories(${ANDROID_NDK}/sources/android/cpufeatures)
+#  add_library(cpufeatures STATIC
+#              ${ANDROID_NDK}/sources/android/cpufeatures/cpu-features.c)
+#  list(APPEND INSTALLED_LIBRARIES cpufeatures)
+#  target_link_libraries(cpufeatures dl)
+#  set(WEBP_DEP_LIBRARIES ${WEBP_DEP_LIBRARIES} cpufeatures)
+#  set(WEBP_DEP_INCLUDE_DIRS ${WEBP_DEP_INCLUDE_DIRS}
+#      ${ANDROID_NDK}/sources/android/cpufeatures)
+#  add_definitions(-DHAVE_CPU_FEATURES_H=1)
+#  set(HAVE_CPU_FEATURES_H 1)
 else()
   set(HAVE_CPU_FEATURES_H 0)
 endif()

aseprite/laf/base/memory.cpp

--- aseprite/laf/base/memory.cpp-old      2024-11-12 01:34:30.572760696 +1100
+++ aseprite/laf/base/memory.cpp  2024-11-11 21:59:51.787887706 +1100
@@ -301,6 +301,13 @@

 #endif

+static void *_aligned_alloc(size_t align, size_t size)
+{
+       void *result = NULL;
+       posix_memalign(&result, align, size);
+       return result;
+}
+
 void* base_aligned_alloc(std::size_t bytes, std::size_t alignment)
 {
 #if LAF_WINDOWS
@@ -310,7 +317,7 @@
   std::size_t misaligned = (bytes % alignment);
   if (misaligned > 0)
     bytes += alignment - misaligned;
-  return aligned_alloc(alignment, bytes);
+  return _aligned_alloc(alignment, bytes);
 #endif
 }

aseprite/third_party/harfbuzz/src/hb.hh

--- aseprite/third_party/harfbuzz/src/hb.hh-old   2024-11-12 01:47:10.084760406 +1100
+++ aseprite/third_party/harfbuzz/src/hb.hh       2024-11-11 20:49:21.005342346 +1100
@@ -125,6 +125,7 @@

 /* Ignored intentionally. */
 #ifndef HB_NO_PRAGMA_GCC_DIAGNOSTIC_IGNORED
+#pragma GCC diagnostic ignored "-Wcast-function-type-strict"
 #pragma GCC diagnostic ignored "-Wclass-memaccess"
 #pragma GCC diagnostic ignored "-Wformat-nonliteral"
 #pragma GCC diagnostic ignored "-Wformat-zero-length"

aseprite/laf/base/thread.cpp

--- aseprite/laf/base/thread.cpp-old	2024-11-12 18:00:13.921465234 +1100
+++ aseprite/laf/base/thread.cpp	2024-11-12 19:44:43.821462842 +1100
@@ -111,6 +111,8 @@
 #endif
 }
 
+extern "C" int pthread_getname_np(pthread_t __pthread, char* _Nonnull __buf, size_t __n);
+
 std::string this_thread::get_name()
 {
 #if LAF_WINDOWS

deps/skia/src/ports/SkDebug_stdio.cpp

--- deps/skia/src/ports/SkDebug_stdio.cpp-old       2024-11-12 01:23:35.060760946 +1100
+++ deps/skia/src/ports/SkDebug_stdio.cpp   2024-11-12 01:07:07.941801219 +1100
@@ -6,7 +6,7 @@
  */

 #include "include/core/SkTypes.h"
-#if !defined(SK_BUILD_FOR_WIN) && !defined(SK_BUILD_FOR_ANDROID)
+//#if !defined(SK_BUILD_FOR_WIN) && !defined(SK_BUILD_FOR_ANDROID)

 #include <stdarg.h>
 #include <stdio.h>
@@ -17,4 +17,4 @@
     vfprintf(stderr, format, args);
     va_end(args);
 }
-#endif//!defined(SK_BUILD_FOR_WIN) && !defined(SK_BUILD_FOR_ANDROID)
+//#endif//!defined(SK_BUILD_FOR_WIN) && !defined(SK_BUILD_FOR_ANDROID)

aseprite/laf/base/launcher.cpp (for desktop xdg-open)

--- aseprite/laf/base/launcher.cpp-old	2024-11-13 02:14:37.807500767 +1100
+++ aseprite/laf/base/launcher.cpp	2024-11-13 02:15:29.651500747 +1100
@@ -83,7 +83,7 @@
   #if __APPLE__
     ret = std::system(("open \"" + file + "\"").c_str());
   #else
-    ret = std::system(("setsid xdg-open \"" + file + "\"").c_str());
+    ret = std::system(("setsid xdg-utils-xdg-open \"" + file + "\"").c_str());
   #endif
 
 #endif
@@ -124,7 +124,7 @@
     if (!base::is_directory(file))
       file = base::get_file_path(file);
 
-    const int ret = std::system(("setsid xdg-open \"" + file + "\"").c_str());
+    const int ret = std::system(("setsid xdg-utils-xdg-open \"" + file + "\"").c_str());
     return (ret == 0);
 
   #endif

optional: patch for termux prefix paths (permission denials might happen if not applied)

--- aseprite/laf/base/fs_unix.h-old	2024-11-12 10:29:41.275809946 +1100
+++ aseprite/laf/base/fs_unix.h	2024-11-12 10:30:05.603809937 +1100
@@ -197,7 +197,7 @@
   char* tmpdir = getenv("TMPDIR");
   if (tmpdir)
     return tmpdir;
-  return "/tmp";
+  return "/data/data/com.termux/files/usr/tmp";
 }
 
 std::string get_user_docs_folder()

--- aseprite/third_party/jpeg/jmemname.c-old	2024-11-12 14:46:43.816006705 +1100
+++ aseprite/third_party/jpeg/jmemname.c	2024-11-12 10:35:06.523877784 +1100
@@ -67,7 +67,7 @@
  */
 
 #ifndef TEMP_DIRECTORY          /* can override from jconfig.h or Makefile */
-#define TEMP_DIRECTORY  "/usr/tmp/" /* recommended setting for Unix */
+#define TEMP_DIRECTORY  "/data/data/com.termux/files/usr/tmp/" /* recommended setting for Unix */
 #endif
 
 static int next_file_num;       /* to distinguish among several temp files */

--- aseprite/third_party/libarchive/libarchive/archive_util.c-old	2024-11-12 10:48:51.826118583 +1100
+++ aseprite/third_party/libarchive/libarchive/archive_util.c	2024-11-12 10:49:24.166118571 +1100
@@ -404,7 +404,7 @@
 #ifdef _PATH_TMP
 		tmp = _PATH_TMP;
 #else
-                tmp = "/tmp";
+                tmp = "/data/data/com.termux/files/usr/tmp";
 #endif
 	archive_strcpy(temppath, tmp);
 	if (temppath->s[temppath->length-1] != '/')

--- aseprite/third_party/lua/loslib.c-old        2024-11-12 10:32:26.339877845 +1100
+++ aseprite/third_party/lua/loslib.c    2024-11-12 10:33:30.323877821 +1100
@@ -105,10 +105,10 @@
 
 #include <unistd.h>
 
-#define LUA_TMPNAMBUFSIZE	32
+#define LUA_TMPNAMBUFSIZE	256
 
 #if !defined(LUA_TMPNAMTEMPLATE)
-#define LUA_TMPNAMTEMPLATE	"/tmp/lua_XXXXXX"
+#define LUA_TMPNAMTEMPLATE     "/data/data/com.termux/files/usr/tmp/lua_XXXXXX"
 #endif

 #define lua_tmpnam(b,e) { \

--- aseprite/third_party/lua/luaconf.h-old	2024-11-12 21:07:04.385684895 +1100
+++ aseprite/third_party/lua/luaconf.h	2024-11-12 21:09:20.765684843 +1100
@@ -223,7 +223,7 @@
 
 #else			/* }{ */
 
-#define LUA_ROOT	"/usr/local/"
+#define LUA_ROOT	"/data/data/com.termux/files/usr/"
 #define LUA_LDIR	LUA_ROOT "share/lua/" LUA_VDIR "/"
 #define LUA_CDIR	LUA_ROOT "lib/lua/" LUA_VDIR "/"

--- aseprite/src/app/font_path_unix.cpp-old	2024-11-12 21:10:58.769684805 +1100
+++ aseprite/src/app/font_path_unix.cpp	2024-11-12 21:14:40.429684721 +1100
@@ -27,8 +27,7 @@
 
   std::queue<std::string> q;
   q.push("~/.fonts");
-  q.push("/usr/local/share/fonts");
-  q.push("/usr/share/fonts");
+  q.push("/data/data/com.termux/files/usr/share/fonts");
 
   while (!q.empty()) {
     std::string fontDir = q.front();

--- deps/skia/src/core/SkVM.cpp-old	2024-11-12 14:16:05.844265984 +1100
+++ deps/skia/src/core/SkVM.cpp	2024-11-12 14:18:54.854086279 +1100
@@ -3054,7 +3054,7 @@
         SkASSERT(false == llvm::verifyModule(*mod, &llvm::outs()));
 
         if (true) {
-            SkString path = SkStringPrintf("/tmp/%s.bc", debug_name);
+            SkString path = SkStringPrintf("/data/data/com.termux/files/tmp/%s.bc", debug_name);
             std::error_code err;
             llvm::raw_fd_ostream os(path.c_str(), err);
             if (err) {
  1. build skia
cd $HOME/deps/skia
gn gen out/Release-arm64 --args='is_debug=false is_official_build=true skia_use_system_expat=false skia_use_system_icu=false skia_use_system_libjpeg_turbo=false skia_use_system_libpng=false skia_use_system_libwebp=false skia_use_system_zlib=false skia_use_sfntly=false skia_use_freetype=true skia_use_harfbuzz=true skia_pdf_subset_harfbuzz=true skia_use_system_freetype2=false skia_use_system_harfbuzz=false cc="clang" cxx="clang++" extra_cflags_cc=["-stdlib=libc++"] extra_ldflags=["-stdlib=libc++"]'
ninja -C out/Release-arm64 skia modules
  1. build aseprite
cd $HOME/aseprite
mkdir build && cd build
cmake \
 -DCMAKE_BUILD_TYPE=RelWithDebInfo \
 -DCMAKE_CXX_FLAGS:STRING=-stdlib=libc++ \
 -DCMAKE_EXE_LINKER_FLAGS:STRING=-stdlib=libc++ \
 -DCMAKE_C_COMPILER=clang \
 -DCMAKE_CXX_COMPILER=clang++ \
 -DLAF_BACKEND=skia \
 -DSKIA_DIR=$HOME/deps/skia \
 -DSKIA_LIBRARY_DIR=$HOME/deps/skia/out/Release-arm64 \
 -DLAF_WITH_EXAMPLES=OFF \
 -DENABLE_DESKTOP_INTEGRATION=ON \
 -DCMAKE_INSTALL_PREFIX:PATH=$PREFIX \
 -G Ninja \
 ..
ninja aseprite
ninja install
  1. enjoy!
aseprite

About

Build aseperite for termux

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published