mcpdf

Mcpdf is a drop-in replacement for PDFtk.

License

License

Categories

Categories

CLI User Interface PDF Data
GroupId

GroupId

aero.m-click
ArtifactId

ArtifactId

mcpdf
Last Version

Last Version

0.2.4
Release Date

Release Date

Type

Type

jar
Description

Description

mcpdf
Mcpdf is a drop-in replacement for PDFtk.
Project URL

Project URL

https://github.com/m-click/mcpdf#readme
Source Code Management

Source Code Management

https://github.com/m-click/mcpdf

Download mcpdf

How to add to project

<!-- https://jarcasting.com/artifacts/aero.m-click/mcpdf/ -->
<dependency>
    <groupId>aero.m-click</groupId>
    <artifactId>mcpdf</artifactId>
    <version>0.2.4</version>
</dependency>
// https://jarcasting.com/artifacts/aero.m-click/mcpdf/
implementation 'aero.m-click:mcpdf:0.2.4'
// https://jarcasting.com/artifacts/aero.m-click/mcpdf/
implementation ("aero.m-click:mcpdf:0.2.4")
'aero.m-click:mcpdf:jar:0.2.4'
<dependency org="aero.m-click" name="mcpdf" rev="0.2.4">
  <artifact name="mcpdf" type="jar" />
</dependency>
@Grapes(
@Grab(group='aero.m-click', module='mcpdf', version='0.2.4')
)
libraryDependencies += "aero.m-click" % "mcpdf" % "0.2.4"
[aero.m-click/mcpdf "0.2.4"]

Dependencies

compile (3)

Group / Artifact Type Version
org.bouncycastle : bcpkix-jdk15on jar 1.52
org.bouncycastle : bcprov-jdk15on jar 1.52
com.itextpdf : itextpdf jar 5.5.5

Project Modules

There are no modules declared in this project.

Mcpdf

Mcpdf is an alternative to PDFtk with fixed unicode issues, so you can write Łódź into your forms.

It implements a small subset of PDFtk for which it implements compatible command line interface, so it can be used as a drop-in replacement for this subset of commands.

Internally it uses the iText PDF library.

Getting Started

Make sure you have installed a Java Runtime Environment such as OpenJDK.

Download the latest standalone version of Mcpdf (jar-with-dependencies).

For the sake of brevity, we will refer to this file as mcpdf.jar. So you should either rename the file or create a symlink:

ln -s mcpdf-0.2.4-jar-with-dependencies.jar mcpdf.jar

Test it via:

java -jar mcpdf.jar

Usage

For the implemented subset of commands (see below), Mcpdf can be used as a drop-in replacement for PDFtk, taking a PDFtk command and replace pdftk with java -jar mcpdf.jar.

Please create an issue tracker entry if you would like to add more commands.

Fill in form data

Fill in form data from DATA.xfdf into FORM.pdf and write the result to OUTPUT.pdf:

java -jar mcpdf.jar FORM.pdf fill_form - output - < DATA.xfdf > OUTPUT.pdf

Fill in form data and flatten the document to prevent further editing:

java -jar mcpdf.jar FORM.pdf fill_form - output - flatten < DATA.xfdf > OUTPUT.pdf

Add stamp and/or background

Use BACKGROUND.pdf as a background for INPUT.pdf and output to OUTPUT.pdf:

java -jar mcpdf.jar INPUT.pdf background BACKGROUND.pdf output - > OUTPUT.pdf

Similarly, you can use the stamp functionality to add STAMP.pdf as a stamp (i.e. foreground) for INPUT.pdf and output into OUTPUT.pdf. This works just like background, except that it places STAMP.pdf in front of INPUT.pdf instead of behind it:

java -jar mcpdf.jar INPUT.pdf stamp STAMP.pdf output - > OUTPUT.pdf

Advanced Topics

Combine with Another Library Version

Download the plain JAR file (mcpdf-0.2.4.jar) instead of the jar-with-dependencies.

Download the version of the iText PDF library you want to use (itextpdf-X.Y.Z.jar).

Run both in combination:

java -cp itextpdf-X.Y.Z.jar:mcpdf-0.2.4.jar aero.m_click.mcpdf.Main

Build from Source

Make sure you have installed Maven and Git.

Download the latest Mcpdf source and change into that folder:

git clone https://github.com/m-click/mcpdf.git
cd mcpdf

Build the plain JAR file as well as the jar-with-dependencies:

mvn package

This will download the correct version of the iText PDF library and all required Maven modules automatically.

You will find the JAR files in the target subfolder.

Deploy Releases

Mcpdf uses the Sonatype OSSRH (OSS Repository Hosting Service). The project creation ticket was OSSRH-8759.

Create ~/.m2/settings.xml:

<settings>
  <servers>
    <server>
      <id>sonatype-nexus-snapshots</id>
      <username>...</username>
      <password>...</password>
    </server>
    <server>
      <id>sonatype-nexus-staging</id>
      <username>...</username>
      <password>...</password>
    </server>
  </servers>
</settings>

Prepare documentation:

VERSION=`sed -n 's/^  <version>\([^-]*\).*/\1/p' pom.xml`
sed -i "s,mcpdf\([-/]\)[0-9.]*[0-9],mcpdf\1$VERSION,g" README.md
git commit -m "Prepare documentation for release mcpdf-$VERSION" README.md

Create a new release and upload it to the OSSRH staging area:

mvn release:clean release:prepare release:perform

Follow the OSSRH release instructions, that is:

  1. Open https://oss.sonatype.org/
  2. Login
  3. Select Staging Repositories
  4. Select topmost item
  5. Click Close and Confirm
  6. Click Refresh a few times
  7. Click Release and Confirm
  8. Watch it appear at the Central Repository

Push to GitHub:

git push
aero.m-click

m-click.aero

Aviation Software

Versions

Version
0.2.4
0.2.3
0.2.2
0.2.1
0.2.0