//========================================================================
//
// This file comes from pdftohtml project
// http://pdftohtml.sourceforge.net
//
// Copyright from:
// Gueorgui Ovtcharov
// Rainer Dorsch
// Mikhail Kruk
//
//========================================================================
//========================================================================
//
// Modified under the Poppler project - http://poppler.freedesktop.org
//
// All changes made under the Poppler project to this file are licensed
// under GPL version 2 or later
//
// Copyright (C) 2008 Boris Toloknov
// Copyright (C) 2010, 2021, 2022 Albert Astals Cid
// Copyright (C) 2013 Julien Nabet
//
// To see a description of the changes please see the Changelog file that
// came with your tarball or type make ChangeLog if you are building from git
//
//========================================================================
#include "HtmlLinks.h"
extern bool xml;
HtmlLink::HtmlLink(const HtmlLink &x)
{
Xmin = x.Xmin;
Ymin = x.Ymin;
Xmax = x.Xmax;
Ymax = x.Ymax;
dest = new GooString(x.dest);
}
HtmlLink::HtmlLink(double xmin, double ymin, double xmax, double ymax, GooString *_dest)
{
if (xmin < xmax) {
Xmin = xmin;
Xmax = xmax;
} else {
Xmin = xmax;
Xmax = xmin;
}
if (ymin < ymax) {
Ymin = ymin;
Ymax = ymax;
} else {
Ymin = ymax;
Ymax = ymin;
}
dest = new GooString(_dest);
}
HtmlLink::~HtmlLink()
{
delete dest;
}
bool HtmlLink::isEqualDest(const HtmlLink &x) const
{
return (!strcmp(dest->c_str(), x.dest->c_str()));
}
bool HtmlLink::inLink(double xmin, double ymin, double xmax, double ymax) const
{
double y = (ymin + ymax) / 2;
if (y > Ymax) {
return false;
}
return (y > Ymin) && (xmin < Xmax) && (xmax > Xmin);
}
static GooString *EscapeSpecialChars(GooString *s)
{
GooString *tmp = nullptr;
for (int i = 0, j = 0; i < s->getLength(); i++, j++) {
const char *replace = nullptr;
switch (s->getChar(i)) {
case '"':
replace = """;
break;
case '&':
replace = "&";
break;
case '<':
replace = "<";
break;
case '>':
replace = ">";
break;
default:
continue;
}
if (replace) {
if (!tmp) {
tmp = new GooString(s);
}
if (tmp) {
tmp->del(j, 1);
int l = strlen(replace);
tmp->insert(j, replace, l);
j += l - 1;
}
}
}
return tmp ? tmp : s;
}
GooString *HtmlLink::getLinkStart() const
{
GooString *res = new GooString("append(d);
if (d != dest) {
delete d;
}
res->append("\">");
return res;
}
/*GooString* HtmlLink::Link(GooString* content){
//GooString* _dest=new GooString(dest);
GooString *tmp=new GooString("append(dest);
tmp->append("\">");
tmp->append(content);
tmp->append("");
//delete _dest;
return tmp;
}*/
HtmlLinks::HtmlLinks() { }
HtmlLinks::~HtmlLinks() { }
bool HtmlLinks::inLink(double xmin, double ymin, double xmax, double ymax, size_t &p) const
{
for (std::vector::const_iterator i = accu.begin(); i != accu.end(); ++i) {
if (i->inLink(xmin, ymin, xmax, ymax)) {
p = (i - accu.begin());
return true;
}
}
return false;
}
const HtmlLink *HtmlLinks::getLink(size_t i) const
{
return &accu[i];
}