Add libjpeg

This commit is contained in:
crazywhalecc
2026-03-21 17:54:07 +08:00
parent 801d41efeb
commit 36177e4948
2 changed files with 22 additions and 0 deletions

View File

@@ -7,6 +7,10 @@ libjpeg:
metadata:
license-files: [LICENSE.md]
license: IJG
suggests@windows:
- zlib
static-libs@unix:
- libjpeg.a
- libturbojpeg.a
static-libs@windows:
- libjpeg_a.lib

View File

@@ -8,6 +8,8 @@ use StaticPHP\Attribute\Package\BuildFor;
use StaticPHP\Attribute\Package\Library;
use StaticPHP\Package\LibraryPackage;
use StaticPHP\Runtime\Executor\UnixCMakeExecutor;
use StaticPHP\Runtime\Executor\WindowsCMakeExecutor;
use StaticPHP\Util\FileSystem;
#[Library('libjpeg')]
class libjpeg
@@ -25,4 +27,20 @@ class libjpeg
// patch pkgconfig
$lib->patchPkgconfPrefix(['libjpeg.pc', 'libturbojpeg.pc']);
}
#[BuildFor('Windows')]
public function buildWin(LibraryPackage $lib): void
{
WindowsCMakeExecutor::create($lib)
->addConfigureArgs(
'-DENABLE_SHARED=OFF',
'-DENABLE_STATIC=ON',
'-DBUILD_TESTING=OFF',
'-DWITH_JAVA=OFF',
'-DWITH_CRT_DLL=OFF',
)
->optionalPackage('zlib', '-DENABLE_ZLIB_COMPRESSION=ON', '-DENABLE_ZLIB_COMPRESSION=OFF')
->build();
FileSystem::copy("{$lib->getLibDir()}\\jpeg-static.lib", "{$lib->getLibDir()}\\libjpeg_a.lib");
}
}