1 # Makefile - for the org-mode distribution
3 # Maintainer: Carsten Dominik <dominik@science.uva.nl>
6 # To install org-mode, edit the Makefile, type `make', then `make install'.
7 # To create the PDF and HTML documentation files, type `make doc'.
9 ##----------------------------------------------------------------------
10 ## YOU MUST EDIT THE FOLLOWING LINES
11 ##----------------------------------------------------------------------
13 # Name of your emacs binary
16 # Where local software is found
19 # Where local lisp files go
20 lispdir
= $(prefix)/share
/emacs
/site-lisp
23 # $(datadir) contains auxiliary files for use with ODT exporter.
24 # See comments under DATAFILES.
25 datadir = $(prefix)/share
/emacs
/etc
28 infodir = $(prefix)/share
/info
30 ##----------------------------------------------------------------------
31 ## YOU MAY NEED TO EDIT THESE
32 ##----------------------------------------------------------------------
34 # Using emacs in batch mode.
36 BATCH
=$(EMACS
) -batch
-q
-no-site-file
-eval \
37 "(setq load-path (cons (expand-file-name \"./lisp/\") (cons \"$(lispdir)\" load-path)))" $(BATCH_EXTRA
)
39 # Specify the byte-compiler for compiling org-mode files
40 ELC
= $(BATCH
) -f batch-byte-compile
42 # How to make a pdf file from a texinfo file
45 # How to create directories
48 # How to create the info files from the texinfo file
51 # How to create the HTML file
52 TEXI2HTML
= makeinfo --html
--number-sections
53 TEXI2HTMLNOPSLIT
= makeinfo --html
--no-split
--number-sections
55 # How to copy the lisp files and elc files to their distination.
58 # Name of the program to install info files
59 INSTALL_INFO
=install-info
61 ##----------------------------------------------------------------------
62 ## BELOW THIS LINE ON YOUR OWN RISK!
63 ##----------------------------------------------------------------------
65 # The following variables need to be defined by the maintainer
77 org-colview-xemacs.el \
119 org-special-blocks.el \
175 LISPFILES0
= $(LISPF
:%=lisp
/%)
176 LISPFILES
= $(LISPFILES0
) lisp
/org-install.el
177 ELCFILES0
= $(LISPFILES0
:.el
=.elc
)
178 ELCFILES
= $(LISPFILES
:.el
=.elc
)
179 DOCFILES
= doc
/org.texi doc
/org.pdf doc
/org doc
/dir \
180 doc
/pdflayout.sty doc
/.nosearch \
181 doc
/orgguide.texi doc
/orgguide.pdf
182 CARDFILES
= doc
/orgcard.
tex doc
/orgcard.pdf doc
/orgcard_letter.pdf
183 TEXIFILES
= doc
/org.texi
186 # etc/styles contains OpenDocument style files. These files *must* be
187 # installed for the ODT exporter to function. These files are
188 # distirbuted with GNU ELPA as well as with stock Emacs >= 24.1.
190 # contrib/odt/etc/schema contains OpenDocument schema files. It is
191 # *desirable* but *not* mandatory that these files be installed.
192 # These files are not distributed with stock Emacs. This is because
193 # the terms under which OASIS distributes these files are not
196 # BasicODConverter-x.y.z.oxt is a LibreOffice extension for converting
197 # OpenDocument files to numerous other formats. It is similar to
198 # unoconv and is implemented in StarBasic. It is *desirable* but
199 # *not* *mandatory* that the converter be installed. It is
200 # distributed under the same license as GNU Emacs. This file is *not*
202 DATAFILES
= etc
/styles \
203 # contrib/odt/BasicODConverter/BasicODConverter*.oxt \
204 # contrib/odt/etc/schema \
206 # Package Manager (ELPA)
207 PKG_TAG
= $(shell date
+%Y
%m
%d
)
208 PKG_DOC
= "Outline-based notes management and organizer"
211 PKG_FILES
= $(LISPFILES0
) \
218 doc
/orgcard_letter.pdf \
221 .SUFFIXES
: .el .elc .texi
224 # Additional distribution files
225 DISTFILES_extra
= Makefile request-assign-future.txt contrib etc
227 default
: $(ELCFILES
) $(ELCBFILES
)
229 all: $(ELCFILES
) $(ELCBFILES
) $(INFOFILES
)
239 compile
: $(ELCFILES0
) $(ELCBFILES
)
241 install: install-lisp install-data
243 doc
: doc
/org.html doc
/org.pdf doc
/orgcard.pdf doc
/orgcard_letter.pdf doc
/orgguide.pdf doc
/orgcard.txt
246 ${MAKE} pdf
&& open doc
/org.pdf
249 ${MAKE} pdf
&& open doc
/orgguide.pdf
251 # Always force re-compilation of org-odt
252 lisp
/org-odt.elc
: org-odt-data-dir
255 # Sleight of hand to "hard code" the value of $(datadir) in
256 # org-odt.el. See variables `org-odt-styles-dir-list' and
257 # `org-odt-schema-dir-list'.
258 install-lisp
: BATCH_EXTRA
= -eval
"(setq org-odt-data-dir (expand-file-name \"$(datadir)\"))"
260 install-lisp
: $(LISPFILES
) $(ELCFILES
)
261 if
[ ! -d
$(lispdir
) ]; then
$(MKDIR
) $(lispdir
); else true
; fi
;
262 $(CP
) $(LISPFILES
) $(lispdir
)
263 $(CP
) $(ELCFILES
) $(lispdir
)
265 install-info
: $(INFOFILES
)
266 if
[ ! -d
$(infodir) ]; then
$(MKDIR
) $(infodir); else true
; fi
;
267 $(CP
) $(INFOFILES
) $(infodir)
268 $(INSTALL_INFO
) --infodir=$(infodir) $(INFOFILES
)
270 install-data
: $(DATAFILES
)
271 if
[ ! -d
$(datadir) ]; then
$(MKDIR
) $(datadir); else true
; fi
;
272 $(CP
) $(DATAFILES
) $(datadir)
274 autoloads
: lisp
/org-install.el
276 lisp
/org-install.el
: $(LISPFILES0
) Makefile
277 $(BATCH
) --eval
"(require 'autoload)" \
278 --eval
'(find-file "lisp/org-install.el")' \
279 --eval
'(erase-buffer)' \
280 --eval
'(mapc (lambda (x) (generate-file-autoloads (symbol-name x))) (quote ($(LISPF))))' \
281 --eval
'(insert "\n(provide (quote org-install))\n")' \
282 --eval
'(save-buffer)'
284 doc
/org
: doc
/org.texi
285 (cd doc
&& $(MAKEINFO
) --no-split org.texi
-o org
)
287 doc
/org.pdf
: doc
/org.texi
288 (cd doc
&& $(TEXI2PDF
) org.texi
)
290 doc
/orgguide.pdf
: doc
/orgguide.texi
291 (cd doc
&& $(TEXI2PDF
) orgguide.texi
)
293 doc
/org.html
: doc
/org.texi
294 (cd doc
&& $(TEXI2HTML
) --no-split
-o org.html org.texi
)
295 UTILITIES
/manfull.pl doc
/org.html
297 doc
/orgcard.pdf
: doc
/orgcard.
tex
298 (cd doc
&& pdftex orgcard.
tex)
300 doc
/orgcard.txt
: doc
/orgcard.
tex
301 (cd doc
&& perl ..
/UTILITIES
/orgcard2txt.pl orgcard.
tex > orgcard.txt
)
303 doc
/orgcard_letter.
tex: doc
/orgcard.
tex
304 perl
-pe
's/\\pdflayout=\(0l\)/\\pdflayout=(1l)/' \
305 doc
/orgcard.
tex > doc
/orgcard_letter.
tex
307 doc
/orgcard_letter.pdf
: doc
/orgcard_letter.
tex
308 (cd doc
&& pdftex orgcard_letter.
tex)
310 # Below here are special targets for maintenance only
314 html_manual
: doc
/org.texi
317 $(TEXI2HTML
) -o doc
/manual doc
/org.texi
318 UTILITIES
/mansplit.pl doc
/manual
/*.html
320 html_guide
: doc
/orgguide.texi
323 $(TEXI2HTML
) -o doc
/guide doc
/orgguide.texi
324 UTILITIES
/guidesplit.pl doc
/guide
/*.html
328 pdf
: doc
/org.pdf doc
/orgguide.pdf
330 card
: doc
/orgcard.pdf doc
/orgcard_letter.pdf doc
/orgcard.txt
333 git checkout
-b testrelease
origin/maint
334 git merge
-s recursive
-X theirs master
335 UTILITIES
/set-version.pl testing
336 git commit
-a
-m
"Release testing"
337 make distfile TAG
=testversion
339 rm -rf org-testversion
*
342 git branch
-D testrelease
344 # The following target makes a full release for the stuff that is
345 # currently on master. Do it like this:
347 # make release TAG=7.01
351 git merge
-s recursive
-X theirs master
352 UTILITIES
/set-version.pl
$(TAG
)
353 git commit
-a
-m
"Release $(TAG)"
354 make relup TAG
=$(TAG
)
357 rm -f org-
$(TAG
)*.zip
358 rm -f org-
$(TAG
)*.
tar.gz
359 make pushreleasetag TAG
=$(TAG
)
360 git push
-f
origin maint
362 git merge
-s ours maint
363 UTILITIES
/set-version.pl
-a
$(TAG
)
364 git commit
-a
-m
"Update website to show $(TAG) as current release"
367 # The following target makes a release, but from the stuff that is on
368 # maint, not from the stuff that is on master. The idea is that it pushes
369 # out a minor fix into a minor update, while development on master
370 # already went full steam ahead. To make a micro-relesse, cherry-pick
371 # the necessary changes into maint, then run (with proper version number)
372 # This is just like release, but we skip the step which merges master
375 # make fixrelease TAG=7.01.02
379 git merge
-s recursive
-X theirs master
380 UTILITIES
/set-version.pl
$(TAG
)
381 git commit
-a
-m
"Release $(TAG)"
382 make relup TAG
=$(TAG
)
386 rm org-
$(TAG
)*.
tar.gz
387 make pushreleasetag TAG
=$(TAG
)
388 git push
-f
origin maint
390 git merge
-s ours maint
391 UTILITIES
/set-version.pl
-o
$(TAG
)
392 git commit
-a
-m
"Update website to show $(TAG) as current release"
395 # ~$ make relup only makes sense from orgmode.org server
396 # Don't call it from your computer!
403 @if
[ "X$(TAG)" = "X" ]; then echo
"*** No tag ***"; exit
1; fi
406 UTILITIES
/gplmanual.pl
411 cp org-
$(TAG
).zip org-
$(TAG
).
tar.gz RELEASEDIR
412 cp doc
/org.pdf doc
/orgcard.pdf doc
/org.texi doc
/org.html RELEASEDIR
413 cp doc
/org_dual_license.texi RELEASEDIR
414 cp doc
/orgguide.pdf doc
/orgcard.txt RELEASEDIR
415 cp RELEASEDIR
/org-
$(TAG
).zip RELEASEDIR
/org.zip
416 cp RELEASEDIR
/org-
$(TAG
).
tar.gz RELEASEDIR
/org.
tar.gz
418 # ~$ make sync_release only makes sense from orgmode.org server
419 # Don't call it from your computer!
421 rsync
-avuz RELEASEDIR
/ /var
/www
/orgmode.org
/
423 # ~$ make sync_manual only makes sense from orgmode.org server
424 # Don't call it from your computer!
426 rsync
-avuz
--delete doc
/manual
/ /var
/www
/orgmode.org
/manual
/
427 rsync
-avuz
--delete doc
/guide
/ /var
/www
/orgmode.org
/guide
/
430 @if
[ "X$(TAG)" = "X" ]; then echo
"*** No tag ***"; exit
1; fi
431 touch doc
/org.texi doc
/orgcard.
tex # force update
435 ${MAKE} lisp
/org-install.el
436 rm -rf org-
$(TAG
) org-
$(TAG
).zip
438 $(MKDIR
) org-
$(TAG
)/doc
439 $(MKDIR
) org-
$(TAG
)/lisp
440 cp
-r
$(LISPFILES
) org-
$(TAG
)/lisp
441 cp
-r
$(DOCFILES
) $(CARDFILES
) org-
$(TAG
)/doc
442 cp
-r
$(DISTFILES_extra
) org-
$(TAG
)/
443 cp
-r README_DIST org-
$(TAG
)/README
444 zip
-r org-
$(TAG
).zip org-
$(TAG
)
445 tar zcvf org-
$(TAG
).
tar.gz org-
$(TAG
)
448 @if
[ "X$(PKG_TAG)" = "X" ]; then echo
"*** No tag ***"; exit
1; fi
449 touch doc
/org.texi doc
/orgcard.
tex # force update
452 rm -rf org-
$(PKG_TAG
) org-
$(PKG_TAG
).
tar
453 $(MKDIR
) org-
$(PKG_TAG
)
454 cp
-r
$(PKG_FILES
) org-
$(PKG_TAG
)
455 echo
"(define-package \"org\" \"$(PKG_TAG)\" \"$(PKG_DOC)\" $(PKG_REQ))" > org-
$(PKG_TAG
)/org-pkg.el
456 tar cf org-
$(PKG_TAG
).
tar org-
$(PKG_TAG
) --remove-files
460 rm -f lisp
/org-install.el
469 find contrib
-name \
*~
-exec
rm {} \
;
474 -(cd doc
&& rm -f org.pdf org org.html orgcard.pdf orgguide.pdf
)
475 -(cd doc
&& rm -f
*.aux
*.cp
*.cps
*.
dvi *.fn
*.fns
*.ky
*.kys
*.pg
*.pgs
)
476 -(cd doc
&& rm -f
*.toc
*.tp
*.tps
*.vr
*.vrs
*.log
*.html
*.ps
)
477 -(cd doc
&& rm -f orgcard_letter.
tex orgcard_letter.pdf
)
478 -(cd doc
&& rm -rf manual
)
483 rm -rf org-7
*zip org-7
*tar.gz
490 git push orgmode@orgmode.org
:org-mode.git master
493 git tag
-m
"Adding tag" -a
$(TAG
)
494 git push orgmode@orgmode.org
:org-mode.git
$(TAG
)
497 git tag
-m
"Adding release tag" -a release_
$(TAG
)
498 git push orgmode@orgmode.org
:org-mode.git release_
$(TAG
)
502 lisp
/org.elc
: lisp
/org-macs.el lisp
/org-compat.el lisp
/org-faces.el
503 lisp
/org-agenda.elc
: lisp
/org.el
504 lisp
/org-ascii.elc
: lisp
/org-exp.el
505 lisp
/org-attach.elc
: lisp
/org.el lisp
/org-id.el
506 lisp
/org-archive.elc
: lisp
/org.el
507 lisp
/org-bbdb.elc
: lisp
/org.el
508 lisp
/org-beamer.elc
: lisp
/org.el
509 lisp
/org-bibtex.elc
: lisp
/org.el
510 lisp
/org-capture.elc
: lisp
/org.el lisp
/org-mks.el
511 lisp
/org-clock.elc
: lisp
/org.el
512 lisp
/org-colview.elc
: lisp
/org.el
513 lisp
/org-colview-xemacs.elc
: lisp
/org.el
514 lisp
/org-compat.elc
: lisp
/org-macs.el
515 lisp
/org-crypt.elc
: lisp
/org-crypt.el lisp
/org.el
516 lisp
/org-ctags.elc
: lisp
/org.el
517 lisp
/org-datetree.elc
: lisp
/org.el
518 lisp
/org-docview.elc
: lisp
/org.el
519 lisp
/org-entities.elc
:
520 lisp
/org-exp.elc
: lisp
/org.el lisp
/org-agenda.el
521 lisp
/org-exp-blocks.elc
: lisp
/org.el
522 lisp
/org-latex.elc
: lisp
/org.el lisp
/org-exp.el lisp
/org-beamer.el
523 lisp
/org-docbook.elc
: lisp
/org.el lisp
/org-exp.el
524 lisp
/org-faces.elc
: lisp
/org-macs.el lisp
/org-compat.el
525 lisp
/org-feed.elc
: lisp
/org.el
526 lisp
/org-footnotes.elc
: lisp
/org-macs.el lisp
/org-compat.el
527 lisp
/org-freemind.elc
: lisp
/org.el
528 lisp
/org-gnus.elc
: lisp
/org.el
529 lisp
/org-html.elc
: lisp
/org-exp.el
530 lisp
/org-habit.elc
: lisp
/org.el lisp
/org-agenda.el
531 lisp
/org-icalendar.elc
: lisp
/org-exp.el
532 lisp
/org-id.elc
: lisp
/org.el
533 lisp
/org-indent.elc
: lisp
/org.el lisp
/org-macs.el lisp
/org-compat.el
534 lisp
/org-info.elc
: lisp
/org.el
535 lisp
/org-inlinetask.elc
:
536 lisp
/org-irc.elc
: lisp
/org.el
537 lisp
/org-jsinfo.elc
: lisp
/org.el lisp
/org-exp.el
538 lisp
/org-list.elc
: lisp
/org-macs.el lisp
/org-compat.el
539 lisp
/org-lparse.elc
: lisp
/org-exp.el
540 lisp
/org-mac-message.elc
: lisp
/org.el
542 lisp
/org-mew.elc
: lisp
/org.el
543 lisp
/org-mhe.elc
: lisp
/org.el
545 lisp
/org-mobile.elc
: lisp
/org.el
546 lisp
/org-mouse.elc
: lisp
/org.el
547 lisp
/org-odt.elc
: lisp
/org-lparse.el
548 lisp
/org-plot.elc
: lisp
/org.el lisp
/org-exp.el lisp
/org-table.el
549 lisp
/org-publish.elc
:
550 lisp
/org-protocol.elc
: lisp
/org.el
551 lisp
/org-remember.elc
: lisp
/org.el
552 lisp
/org-rmail.elc
: lisp
/org.el
553 lisp
/org-special-blocks.elc
: lisp
/org-compat.el
554 lisp
/org-src.elc
: lisp
/org-macs.el lisp
/org-compat.el
555 lisp
/org-table.elc
: lisp
/org.el
556 lisp
/org-taskjuggler.elc
: lisp
/org.el lisp
/org-exp.el
557 lisp
/org-timer.elc
: lisp
/org.el
558 lisp
/org-vm.elc
: lisp
/org.el
559 lisp
/org-w3m.elc
: lisp
/org.el
560 lisp
/org-wl.elc
: lisp
/org.el
561 lisp
/org-xoxo.elc
: lisp
/org-exp.el
563 # Describe valid make targets for org-mode.
565 @echo
"make - compile Org ELisp files"
566 @echo
"make clean - clean Elisp and documentation files"
567 @echo
"make all - compile Org ELisp files and documentation"
569 @echo
"make doc - make all documentation"
570 @echo
"make info - make Info documentation"
571 @echo
"make html - make HTML documentation"
572 @echo
"make pdf - make pdf documentation"
573 @echo
"make card - make refcards documentation"
575 @echo
"make install - install Org"
576 @echo
"make install-lisp - install Org ELisp files"
577 @echo
"make install-info - install Org Info file"