Parcourir la source

Renamed XLIBS to config, added -D/-l options

master
Bert il y a 13 ans
Parent
révision
81cfbf171d
4 fichiers modifiés avec 52 ajouts et 30 suppressions
  1. +1
    -1
      .gitignore
  2. +6
    -6
      Makefile
  3. +0
    -23
      XLIBS.c
  4. +45
    -0
      config.c

+ 1
- 1
.gitignore Voir le fichier

@@ -1,4 +1,4 @@
XLIBS
config
config.h
*.o
sxiv


+ 6
- 6
Makefile Voir le fichier

@@ -24,27 +24,27 @@ options:
@echo "CC $<"
@$(CC) $(CFLAGS) -DVERSION=\"$(VERSION)\" -c -o $@ $<

$(OBJ) XLIBS: Makefile config.h
$(OBJ) config: Makefile config.h

XLIBS: XLIBS.c
config: config.c
@$(CC) $(CFLAGS) -o $@ $@.c

config.h:
@echo "creating $@ from config.def.h"
@cp config.def.h $@

sxiv: $(OBJ) XLIBS
sxiv: $(OBJ) config
@echo "CC -o $@"
@$(CC) $(LDFLAGS) -o $@ $(OBJ) $(LIBS) $$(./XLIBS)
@$(CC) $(LDFLAGS) -o $@ $(OBJ) $(LIBS) $$(./config -l)

clean:
@echo "cleaning"
@rm -f $(OBJ) XLIBS sxiv sxiv-$(VERSION).tar.gz
@rm -f $(OBJ) config sxiv sxiv-$(VERSION).tar.gz

dist: clean
@echo "creating dist tarball"
@mkdir -p sxiv-$(VERSION)
@cp LICENSE Makefile README.md config.def.h sxiv.1 $(SRC) XLIBS.c \
@cp LICENSE Makefile README.md config.def.h sxiv.1 $(SRC) config.c \
sxiv-$(VERSION)
@tar -cf sxiv-$(VERSION).tar sxiv-$(VERSION)
@gzip sxiv-$(VERSION).tar


+ 0
- 23
XLIBS.c Voir le fichier

@@ -1,23 +0,0 @@
#define _POSIX_C_SOURCE 200112L
#define _FEATURE_CONFIG

#include <stdio.h>

#include "config.h"

int n = 0;

inline void put_lib_flag(const char *flag, int needed) {
if (needed)
printf("%s%s", n++ ? " " : "", flag);
}

int main(int argc, char **argv) {
put_lib_flag("-lexif", EXIF_SUPPORT);
put_lib_flag("-lgif", GIF_SUPPORT);

if (n)
printf("\n");

return 0;
}

+ 45
- 0
config.c Voir le fichier

@@ -0,0 +1,45 @@
#define _POSIX_C_SOURCE 200112L
#define _FEATURE_CONFIG

#include <stdio.h>
#include <string.h>

#include "config.h"

#define QUOTE(m) #m
#define PUT_MACRO(m) \
printf("%s-D%s=%s", n++ ? " " : "", #m, QUOTE(m))

int n = 0;

inline void puts_if(const char *s, int c) {
if (c)
printf("%s%s", n++ ? " " : "", s);
}

inline void endl() {
if (n) {
printf("\n");
n = 0;
}
}

int main(int argc, char **argv) {
int i;

for (i = 1; i < argc; i++) {
if (!strcmp(argv[i], "-D")) {
PUT_MACRO(EXIF_SUPPORT);
PUT_MACRO(GIF_SUPPORT);
endl();
} else if (!strcmp(argv[i], "-l")) {
puts_if("-lexif", EXIF_SUPPORT);
puts_if("-lgif", GIF_SUPPORT);
endl();
} else {
fprintf(stderr, "%s: invalid argument: %s\n", argv[0], argv[i]);
return 1;
}
}
return 0;
}

Chargement…
Annuler
Enregistrer