diff --git a/src/ng/compile.js b/src/ng/compile.js
index 63eb52fcb77f..82b5c0e59156 100644
--- a/src/ng/compile.js
+++ b/src/ng/compile.js
@@ -847,6 +847,10 @@ function $CompileProvider($provide, $$sanitizeUriProvider) {
? JQLitePrototype.clone.call($compileNodes) // IMPORTANT!!!
: $compileNodes;
+ if ( $linkNode.length === 0 && parentBoundTranscludeFn ) {
+ $linkNode = parentBoundTranscludeFn(scope);
+ }
+
forEach(transcludeControllers, function(instance, name) {
$linkNode.data('$' + name + 'Controller', instance);
});
diff --git a/test/ng/compileSpec.js b/test/ng/compileSpec.js
index 992d7edc51e1..f74cdf0784d8 100755
--- a/test/ng/compileSpec.js
+++ b/test/ng/compileSpec.js
@@ -4097,6 +4097,37 @@ describe('$compile', function() {
});
+ describe('collocated nested transcludes', function() {
+
+ beforeEach(module(function($compileProvider) {
+
+ $compileProvider.directive('inner', valueFn({
+ restrict: 'E',
+ transclude: true,
+ template: ''
+ }));
+
+ $compileProvider.directive('outer', valueFn({
+ restrict: 'E',
+ transclude: true,
+ template: '