mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-09-11 11:49:24 +02:00
* libcups interface unit included in FPC, resolves #32729
git-svn-id: trunk@37619 -
This commit is contained in:
parent
44f04d39a4
commit
4b8dcd676c
4
.gitattributes
vendored
4
.gitattributes
vendored
@ -5180,6 +5180,10 @@ packages/libc/src/wordexph.inc svneol=native#text/plain
|
|||||||
packages/libc/src/wordsizeh.inc svneol=native#text/plain
|
packages/libc/src/wordsizeh.inc svneol=native#text/plain
|
||||||
packages/libc/src/xlocaleh.inc svneol=native#text/plain
|
packages/libc/src/xlocaleh.inc svneol=native#text/plain
|
||||||
packages/libc/src/xopen_limh.inc svneol=native#text/plain
|
packages/libc/src/xopen_limh.inc svneol=native#text/plain
|
||||||
|
packages/libcups/Makefile svneol=native#text/plain
|
||||||
|
packages/libcups/Makefile.fpc svneol=native#text/plain
|
||||||
|
packages/libcups/fpmake.pp svneol=native#text/plain
|
||||||
|
packages/libcups/src/cupsdyn.pp svneol=native#text/pascal
|
||||||
packages/libcurl/Makefile svneol=native#text/plain
|
packages/libcurl/Makefile svneol=native#text/plain
|
||||||
packages/libcurl/Makefile.fpc svneol=native#text/plain
|
packages/libcurl/Makefile.fpc svneol=native#text/plain
|
||||||
packages/libcurl/Makefile.fpc.fpcmake svneol=native#text/plain
|
packages/libcurl/Makefile.fpc.fpcmake svneol=native#text/plain
|
||||||
|
@ -60,6 +60,7 @@
|
|||||||
add_ldap(ADirectory+IncludeTrailingPathDelimiter('ldap'));
|
add_ldap(ADirectory+IncludeTrailingPathDelimiter('ldap'));
|
||||||
add_libc(ADirectory+IncludeTrailingPathDelimiter('libc'));
|
add_libc(ADirectory+IncludeTrailingPathDelimiter('libc'));
|
||||||
add_libcurl(ADirectory+IncludeTrailingPathDelimiter('libcurl'));
|
add_libcurl(ADirectory+IncludeTrailingPathDelimiter('libcurl'));
|
||||||
|
add_libcups(ADirectory+IncludeTrailingPathDelimiter('libcups'));
|
||||||
add_libffi(ADirectory+IncludeTrailingPathDelimiter('libffi'));
|
add_libffi(ADirectory+IncludeTrailingPathDelimiter('libffi'));
|
||||||
add_libmicrohttpd(ADirectory+IncludeTrailingPathDelimiter('libmicrohttpd'));
|
add_libmicrohttpd(ADirectory+IncludeTrailingPathDelimiter('libmicrohttpd'));
|
||||||
add_libgbafpc(ADirectory+IncludeTrailingPathDelimiter('libgbafpc'));
|
add_libgbafpc(ADirectory+IncludeTrailingPathDelimiter('libgbafpc'));
|
||||||
|
@ -350,6 +350,12 @@ begin
|
|||||||
{$include libcurl/fpmake.pp}
|
{$include libcurl/fpmake.pp}
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
procedure add_libcups(const ADirectory: string);
|
||||||
|
begin
|
||||||
|
with Installer do
|
||||||
|
{$include libcups/fpmake.pp}
|
||||||
|
end;
|
||||||
|
|
||||||
procedure add_libffi(const ADirectory: string);
|
procedure add_libffi(const ADirectory: string);
|
||||||
begin
|
begin
|
||||||
with Installer do
|
with Installer do
|
||||||
|
2498
packages/libcups/Makefile
Normal file
2498
packages/libcups/Makefile
Normal file
File diff suppressed because it is too large
Load Diff
102
packages/libcups/Makefile.fpc
Normal file
102
packages/libcups/Makefile.fpc
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
#
|
||||||
|
# Makefile.fpc for running fpmake
|
||||||
|
#
|
||||||
|
|
||||||
|
[package]
|
||||||
|
name=libcups
|
||||||
|
version=3.1.1
|
||||||
|
|
||||||
|
[require]
|
||||||
|
packages=rtl fpmkunit
|
||||||
|
|
||||||
|
[install]
|
||||||
|
fpcpackage=y
|
||||||
|
|
||||||
|
[default]
|
||||||
|
fpcdir=../..
|
||||||
|
|
||||||
|
[prerules]
|
||||||
|
FPMAKE_BIN_CLEAN=$(wildcard ./fpmake$(SRCEXEEXT))
|
||||||
|
ifdef OS_TARGET
|
||||||
|
FPC_TARGETOPT+=--os=$(OS_TARGET)
|
||||||
|
endif
|
||||||
|
ifdef CPU_TARGET
|
||||||
|
FPC_TARGETOPT+=--cpu=$(CPU_TARGET)
|
||||||
|
endif
|
||||||
|
LOCALFPMAKE=./fpmake$(SRCEXEEXT)
|
||||||
|
|
||||||
|
[rules]
|
||||||
|
# Do not pass the Makefile's unit and binary target locations. Fpmake uses it's own.
|
||||||
|
override FPCOPT:=$(filter-out -FU%,$(FPCOPT))
|
||||||
|
override FPCOPT:=$(filter-out -FE%,$(FPCOPT))
|
||||||
|
# Do not pass the package-unitdirectories. Fpmake adds those and this way they don't apear in the .fpm
|
||||||
|
override FPCOPT:=$(filter-out $(addprefix -Fu,$(COMPILER_UNITDIR)),$(FPCOPT))# Compose general fpmake-parameters
|
||||||
|
# Compose general fpmake-parameters
|
||||||
|
ifdef FPMAKEOPT
|
||||||
|
FPMAKE_OPT+=$(FPMAKEOPT)
|
||||||
|
endif
|
||||||
|
FPMAKE_OPT+=--localunitdir=../..
|
||||||
|
FPMAKE_OPT+=--globalunitdir=..
|
||||||
|
FPMAKE_OPT+=$(FPC_TARGETOPT)
|
||||||
|
FPMAKE_OPT+=$(addprefix -o ,$(FPCOPT))
|
||||||
|
FPMAKE_OPT+=--compiler=$(FPC)
|
||||||
|
FPMAKE_OPT+=-bu
|
||||||
|
.NOTPARALLEL:
|
||||||
|
|
||||||
|
fpmake$(SRCEXEEXT): fpmake.pp
|
||||||
|
$(FPCFPMAKE) fpmake.pp $(FPMAKE_SKIP_CONFIG) $(addprefix -Fu,$(COMPILER_FPMAKE_UNITDIR)) $(FPCMAKEOPT) $(OPT)
|
||||||
|
all: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) compile $(FPMAKE_OPT)
|
||||||
|
smart: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) compile $(FPMAKE_OPT) -o -XX -o -CX
|
||||||
|
release: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) compile $(FPMAKE_OPT) -o -dRELEASE
|
||||||
|
debug: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) compile $(FPMAKE_OPT) -o -dDEBUG
|
||||||
|
# If no fpmake exists and (dist)clean is called, do not try to build fpmake, it will
|
||||||
|
# most often fail because the dependencies are cleared.
|
||||||
|
# In case of a clean, simply do nothing
|
||||||
|
ifeq ($(FPMAKE_BIN_CLEAN),)
|
||||||
|
clean:
|
||||||
|
else
|
||||||
|
clean:
|
||||||
|
$(FPMAKE_BIN_CLEAN) clean $(FPMAKE_OPT)
|
||||||
|
endif
|
||||||
|
# In case of a distclean, perform an 'old'-style distclean. This to avoid problems
|
||||||
|
# when the package is compiled using fpcmake prior to running this clean using fpmake
|
||||||
|
ifeq ($(FPMAKE_BIN_CLEAN),)
|
||||||
|
distclean: $(addsuffix _distclean,$(TARGET_DIRS)) fpc_cleanall
|
||||||
|
else
|
||||||
|
distclean:
|
||||||
|
ifdef inUnix
|
||||||
|
{ $(FPMAKE_BIN_CLEAN) distclean $(FPMAKE_OPT); if [ $$? != "0" ]; then { echo Something wrong with fpmake exectable. Remove the executable and call make recursively to recover.; $(DEL) $(FPMAKE_BIN_CLEAN); $(MAKE) fpc_cleanall; }; fi; }
|
||||||
|
else
|
||||||
|
$(FPMAKE_BIN_CLEAN) distclean $(FPMAKE_OPT)
|
||||||
|
endif
|
||||||
|
-$(DEL) $(LOCALFPMAKE)
|
||||||
|
endif
|
||||||
|
cleanall: distclean
|
||||||
|
install: fpmake$(SRCEXEEXT)
|
||||||
|
ifdef UNIXHier
|
||||||
|
$(LOCALFPMAKE) install $(FPMAKE_OPT) --prefix=$(INSTALL_PREFIX) --baseinstalldir=$(INSTALL_LIBDIR)/fpc/$(FPC_VERSION) --unitinstalldir=$(INSTALL_UNITDIR)
|
||||||
|
else
|
||||||
|
$(LOCALFPMAKE) install $(FPMAKE_OPT) --prefix=$(INSTALL_BASEDIR) --baseinstalldir=$(INSTALL_BASEDIR) --unitinstalldir=$(INSTALL_UNITDIR)
|
||||||
|
endif
|
||||||
|
# distinstall also installs the example-sources and omits the location of the source-
|
||||||
|
# files from the fpunits.cfg files.
|
||||||
|
distinstall: fpmake$(SRCEXEEXT)
|
||||||
|
ifdef UNIXHier
|
||||||
|
$(LOCALFPMAKE) install $(FPMAKE_OPT) --prefix=$(INSTALL_PREFIX) --baseinstalldir=$(INSTALL_LIBDIR)/fpc/$(FPC_VERSION) --unitinstalldir=$(INSTALL_UNITDIR) -ie -fsp 0
|
||||||
|
else
|
||||||
|
$(LOCALFPMAKE) install $(FPMAKE_OPT) --prefix=$(INSTALL_BASEDIR) --baseinstalldir=$(INSTALL_BASEDIR) --unitinstalldir=$(INSTALL_UNITDIR) -ie -fsp 0
|
||||||
|
endif
|
||||||
|
zipinstall: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) zipinstall $(FPMAKE_OPT) --zipprefix=$(DIST_DESTDIR)/$(ZIPPREFIX)
|
||||||
|
zipdistinstall: fpmake$(SRCEXEEXT)
|
||||||
|
$(LOCALFPMAKE) zipinstall $(FPMAKE_OPT) --zipprefix=$(DIST_DESTDIR)/$(ZIPPREFIX) -ie -fsp 0
|
||||||
|
zipsourceinstall: fpmake$(SRCEXEEXT)
|
||||||
|
ifdef UNIXHier
|
||||||
|
$(LOCALFPMAKE) archive $(FPMAKE_OPT) --zipprefix=$(DIST_DESTDIR)/$(ZIPPREFIX) --prefix=share/src/fpc-\$$\(PACKAGEVERSION\)/$(INSTALL_FPCSUBDIR)/\$$\(PACKAGEDIRECTORY\)
|
||||||
|
else
|
||||||
|
$(LOCALFPMAKE) archive $(FPMAKE_OPT) --zipprefix=$(DIST_DESTDIR)/$(ZIPPREFIX) --prefix=source\\$(INSTALL_FPCSUBDIR)\\\$$\(PACKAGEDIRECTORY\)
|
||||||
|
endif
|
44
packages/libcups/fpmake.pp
Normal file
44
packages/libcups/fpmake.pp
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{$ifndef ALLPACKAGES}
|
||||||
|
{$mode objfpc}{$H+}
|
||||||
|
program fpmake;
|
||||||
|
|
||||||
|
uses fpmkunit;
|
||||||
|
|
||||||
|
Var
|
||||||
|
P : TPackage;
|
||||||
|
T : TTarget;
|
||||||
|
begin
|
||||||
|
With Installer do
|
||||||
|
begin
|
||||||
|
{$endif ALLPACKAGES}
|
||||||
|
|
||||||
|
P:=AddPackage('libcups');
|
||||||
|
{$ifdef ALLPACKAGES}
|
||||||
|
P.Directory:=ADirectory;
|
||||||
|
{$endif ALLPACKAGES}
|
||||||
|
P.Version:='3.1.1';
|
||||||
|
|
||||||
|
P.Author := 'Header: Olivier GUILBAUD';
|
||||||
|
P.License := 'Header: LGPL with modi ';
|
||||||
|
P.HomepageURL := 'www.freepascal.org';
|
||||||
|
P.OSes := [beos,haiku,freebsd,darwin,iphonesim,solaris,netbsd,openbsd,linux,aix,dragonfly];
|
||||||
|
P.Email := '';
|
||||||
|
P.Description := 'This package provides an interface with Common UNIX Printing System.';
|
||||||
|
P.NeedLibC:= false; // true for headers that indirectly link to libc?
|
||||||
|
|
||||||
|
P.Dependencies.Add('rtl-extra');
|
||||||
|
|
||||||
|
P.SourcePath.Add('src');
|
||||||
|
|
||||||
|
T:=P.Targets.AddUnit('cupsdyn.pp');
|
||||||
|
|
||||||
|
P.ExamplePath.Add('examples');
|
||||||
|
// P.Targets.AddExampleProgram('testcups.pp');
|
||||||
|
// P.Sources.AddExampleFiles('examples/*',P.Directory,false,'.');
|
||||||
|
|
||||||
|
|
||||||
|
{$ifndef ALLPACKAGES}
|
||||||
|
Run;
|
||||||
|
end;
|
||||||
|
end.
|
||||||
|
{$endif ALLPACKAGES}
|
1391
packages/libcups/src/cupsdyn.pp
Normal file
1391
packages/libcups/src/cupsdyn.pp
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user