diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/output/modifiers/__tests__/resolveLinks.js | 14 | ||||
-rw-r--r-- | lib/output/modifiers/resolveLinks.js | 16 |
2 files changed, 21 insertions, 9 deletions
diff --git a/lib/output/modifiers/__tests__/resolveLinks.js b/lib/output/modifiers/__tests__/resolveLinks.js index e42b619..c57346a 100644 --- a/lib/output/modifiers/__tests__/resolveLinks.js +++ b/lib/output/modifiers/__tests__/resolveLinks.js @@ -40,9 +40,8 @@ describe('resolveLinks', function() { }); describe('Anchor', function() { - var TEST = '<p>This is a <a href="test/cool.md#an-anchor"></a></p>'; - it('should prevent anchors in resolution', function() { + var TEST = '<p>This is a <a href="test/cool.md#an-anchor"></a></p>'; var $ = cheerio.load(TEST); return resolveLinks('hello.md', resolveFileCustom, $) @@ -51,6 +50,17 @@ describe('resolveLinks', function() { expect(link.attr('href')).toBe('test/cool.html#an-anchor'); }); }); + + it('should ignore pure anchor links', function() { + var TEST = '<p>This is a <a href="#an-anchor"></a></p>'; + var $ = cheerio.load(TEST); + + return resolveLinks('hello.md', resolveFileCustom, $) + .then(function() { + var link = $('a'); + expect(link.attr('href')).toBe('#an-anchor'); + }); + }); }); describe('Custom Resolver', function() { diff --git a/lib/output/modifiers/resolveLinks.js b/lib/output/modifiers/resolveLinks.js index 907a667..0dd46bb 100644 --- a/lib/output/modifiers/resolveLinks.js +++ b/lib/output/modifiers/resolveLinks.js @@ -30,16 +30,18 @@ function resolveLinks(currentFile, resolveFile, $) { // Split anchor var parsed = url.parse(href); - href = parsed.pathname; + href = parsed.pathname || ''; - // Calcul absolute path for this - href = LocationUtils.toAbsolute(href, currentDirectory, '.'); + if (href) { + // Calcul absolute path for this + href = LocationUtils.toAbsolute(href, currentDirectory, '.'); - // Resolve file - href = resolveFile(href); + // Resolve file + href = resolveFile(href); - // Convert back to relative - href = LocationUtils.relative(currentDirectory, href); + // Convert back to relative + href = LocationUtils.relative(currentDirectory, href); + } // Add back anchor href = href + (parsed.hash || ''); |