6

我正在使用一个大型开源库,需要生成一些类的个人子类。什么是最好的策略?我想保持原始库不变,并且在更新时能够轻松地重新配置。我的代码不太可能值得为该项目做出贡献(尽管我很高兴以允许这样做的方式编写)。

这个问题是一个普遍的问题,但我会用我的例子来说明它。我正在使用Apache PDFBox,它有一个例程可以写入java.awt.Graphics2D. 我已将其替换为 Apache Batik工具包,该工具包提供了 Graphics2D ( org.apache.batik.svggen.SVGGraphics2D) 的子类,因此我可以捕获 SVG 表示。我创建一个实例

public static org.apache.batik.svggen.SVGGraphics2D createSVG() {
    org.w3c.dom.DOMImplementation domImpl =
    org.apache.batik.dom.GenericDOMImplementation.getDOMImplementation();
        org.w3c.dom.Document document = 
            domImpl.createDocument("http://www.w3.org/2000/svg", "svg", null);
        return new org.apache.batik.svggen.SVGGraphics2D(document);
    }

PDFBox 使用图形的地方是org.apache.pdfbox.PDFReader我已经编辑以允许新图形的地方:

    protected void showPage(int pageNumber)
{
    try 
    {
        PageDrawer drawer = new PageDrawer();
        PageWrapper wrapper = new PageWrapper( this );
        PDPage page = (PDPage)pages.get(pageNumber);
        wrapper.displayPage( page );
        PDRectangle cropBox = page.findCropBox();
        Dimension drawDimension = cropBox.createDimension();
        svg = PDFPagePanel.createSVG();          // MY EDIT!!!!!!!!!
        drawer.drawPage( svg, page, drawDimension );
        writeSVG(pageNumber);
    }
    catch (IOException exception)
    {
        exception.printStackTrace();
    }
}

我已经让它工作了(这不是问题)。我担心的是,我不得不破解/编辑和重新编译一些分布式 PDFBox 类,只是为了生成和使用子类。我最终在与库相同的包中得到了诸如 PMRPDFReader 之类的类。非常混乱 - 我不记得我在哪里进行了编辑,等等。

我觉得我应该能够按原样使用库并简单地添加/链接我的子类。我使用 maven,所以也许有一种方法可以排除原始类。

4

2 回答 2

1

如果库没有提供简单的子类钩子,那么你没有太多选择。鉴于他们有一个 git 镜像,我只是分叉它(将您的镜像保存在安全和备份的地方,最好靠近您的正常 SCM)。我通常的策略是将 -companyName 附加到版本号(在 Maven 中),这样我就可以记住它是一个补丁版本。您可以轻松查看所做的编辑,因为它们将在您的修订历史记录中。

您还可以调查使用 maven shade 插件来更改/替换类,但这有点 hackier 恕我直言。

于 2012-04-25T09:27:48.473 回答
1

这是我将如何做到这一点:

  • 创建一个包含源代码更改的单独项目。将其检入源代码/修订控制(SVN、Git,无论您使用什么)。此项目将仅包含您的更改。
  • 确保它是一个 Maven 项目。使用与原始开源项目相同的版本号,但在版本中添加一个附录。如果您使用的是1.2版本,请创建您的项目以使用1.2-Peter-1或类似版本。这样,您将始终知道它基于哪个版本,您还可以提供更改的多个版本/修订。它也不会与官方版本冲突。使用与官方相同的组/工件 ID。
  • 将原始项目用作您自己的依赖项。

对于部署,您有两种选择:

于 2012-04-25T09:32:54.733 回答