Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added initial CPack Configuration. #17

Draft
wants to merge 2 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
out/
.vs/
CMakeSettings.json
26 changes: 26 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
cmake_minimum_required(VERSION 3.28)

project(PkgDecrypt)

add_subdirectory(libb64)
add_subdirectory(aes)
add_subdirectory(zlib)

add_library(keyflate STATIC keyflate.c)
target_link_libraries(keyflate PRIVATE ZLIB::ZLIB)

add_executable(make_key make_key.c)
target_link_libraries(make_key PRIVATE b64 keyflate)
target_include_directories(make_key PRIVATE libb64)
# Couple EXE with zlib DLL on Windows and bundle other things together. Grabbed from here: https://stackoverflow.com/a/75065206
# Hoping this isn't needed with the zlib-cmake project, but it's here just in case.
# install(TARGETS make_key
# RUNTIME ARCHIVE LIBRARY RUNTIME FRAMEWORK BUNDLE PUBLIC_HEADER RESOURCE)

add_executable(pkg_dec pkg_dec.c)
target_link_libraries(pkg_dec PRIVATE b64 keyflate aes)
target_include_directories(pkg_dec PRIVATE libb64)
# Couple EXE with zlib DLL on Windows and bundle other things together. Grabbed from here: https://stackoverflow.com/a/75065206
# Hoping this isn't needed with the zlib-cmake project, but it's here just in case.
# install(TARGETS pkg_dec
# RUNTIME ARCHIVE LIBRARY RUNTIME FRAMEWORK BUNDLE PUBLIC_HEADER RESOURCE)
8 changes: 8 additions & 0 deletions aes/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
cmake_minimum_required(VERSION 3.13)
project(aes)

set(SOURCE_FILES
aes.c
)

add_library(${PROJECT_NAME} ${SOURCE_FILES})
21 changes: 21 additions & 0 deletions cmake/Packaging-Information.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Information needed for packaging. For Termux DEB generation, this will try installing into /usr/opt by default.
# To prevent this behavior on Termux, '-DCPACK_PACKAGING_INSTALL_PREFIX=/data/data/com.termux/files/usr/' will need to be passed in at configuration or packaging time.
# Template parts grabbed from: https://decovar.dev/blog/2021/09/23/cmake-cpack-package-deb-apt/

set(CPACK_PACKAGE_NAME ${PROJECT_NAME}
CACHE STRING "The resulting package name"
)
# This can also be set in the toplevel CMakeLists.txt within with 'project(<NAME> HOMEPAGE-URL "<URL>")' if that's preferred.
set(CPACK_PACKAGE_HOMEPAGE_URL "https://github.com/st4rk/PkgDecrypt")
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Decrypts PSVita PKG files and creates zRIFs from NoNPDRM fake licenses."
CACHE STRING "Package description for the package metadata"
)
set(CPACK_PACKAGE_VENDOR "st4rk")
set(CPACK_DEBIAN_PACKAGE_MAINTAINER "Unknown")
set(CPACK_RESOURCE_FILE_README "${CMAKE_CURRENT_SOURCE_DIR}/README.md")

set(CPACK_VERBATIM_VARIABLES YES)

set(CPACK_PACKAGE_INSTALL_DIRECTORY ${CPACK_PACKAGE_NAME})

include(CPack)
14 changes: 14 additions & 0 deletions libb64/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
cmake_minimum_required(VERSION 3.28)
# set(CMAKE_C_STANDARD)
# set(CMAKE_CXX_STANDARD)

project(b64)

add_subdirectory(b64)

set(SOURCE_FILES
cdecode.c
cencode.c
)
add_library(${PROJECT_NAME} ${SOURCE_FILES})
include_directories(.)
13 changes: 13 additions & 0 deletions libb64/b64/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
cmake_minimum_required(VERSION 3.28)
# target_sources(PRIVATE FILE_SET b64
# TYPE HEADERS
# FILES cdecrypt.h
# cencrypt.h)
# target_sources(PUBLIC FILE-SET testset TYPE HEADERS FILES
# cdecrypt.h
# cencrypt.h
# )
include_directories(b64, AFTER PRIVATE
cdecrypt.h
cencrypt.h
)
30 changes: 30 additions & 0 deletions zlib/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Downloads ZLIB-1.3.1 if it's not already available. Uses: https://github.com/jimmy-park/zlib-cmake

cmake_minimum_required(VERSION 3.28)
include(FetchContent)

FetchContent_Declare(
zlib-cmake
URL https://github.com/jimmy-park/zlib-cmake/archive/main.zip
)
FetchContent_MakeAvailable(zlib-cmake)



# This is my previous failed attempt. It required downloading ZLIB manually and is errorprone.
# If ZLIB-NG is prefered, I found that building ZLIB as a shared library and replacing the Windows
# DLL with a prebuilt version of ZLIB-NG works well enough, though is too hacky. I'd prefer to
# build ZLIB-NG along with PkgDecrypt and any other project.

# set(USED_ZLIB_LIBRARY zlib-1.3.1 CACHE STRING "What flavor of ZLIB to use")

# if(${USED_ZLIB_LIBRARY} EQUAL zlib-1.3.1)
# add_subdirectories(${CMAKE_CURRENT_BINARY_DIR}/zlib_build)
# set(ZLIB_BUILD_EXAMPLES OFF)
# endif()

# if(${USED_ZLIB_LIBRARY} EQUAL zlib-ng-develop)
# TODO: Fix this. Include names not correct.
# endif()

# add_subdirectory(${USED_ZLIB_LIBRARY})