UNPKG

@wojtekmaj/enzyme-adapter-react-17

Version:
174 lines (169 loc) 18.8 kB
"use strict"; // Extracted from https://github.com/facebook/react/blob/a724a3b578dce77d427bef313102a4d0e978d9b4/packages/react-reconciler/src/ReactFiberTreeReflection.js var HostRoot = 3; var Placement = 2; var Hydrating = 4096; var NoFlags = 0; function getNearestMountedFiber(fiber) { var node = fiber; var nearestMounted = fiber; if (!fiber.alternate) { // If there is no alternate, this might be a new tree that isn't inserted // yet. If it is, then it will have a pending insertion effect on it. var nextNode = node; do { node = nextNode; if ((node.flags & (Placement | Hydrating)) !== NoFlags) { // This is an insertion or in-progress hydration. The nearest possible // mounted fiber is the parent but we need to continue to figure out // if that one is still mounted. nearestMounted = node["return"]; } nextNode = node["return"]; } while (nextNode); } else { while (node["return"]) { node = node["return"]; } } if (node.tag === HostRoot) { // TODO: Check if this was a nested HostRoot when used with // renderContainerIntoSubtree. return nearestMounted; } // If we didn't hit the root, that means that we're in an disconnected tree // that has been unmounted. return null; } function findCurrentFiberUsingSlowPath(fiber) { var _a$stateNode; var alternate = fiber.alternate; if (!alternate) { // If there is no alternate, then we only need to check if it is mounted. var nearestMounted = getNearestMountedFiber(fiber); if (nearestMounted === null) { throw new Error('Unable to find node on an unmounted component.'); } if (nearestMounted !== fiber) { return null; } return fiber; } // If we have two possible branches, we'll walk backwards up to the root // to see what path the root points to. On the way we may hit one of the // special cases and we'll deal with them. var a = fiber; var b = alternate; // eslint-disable-next-line no-constant-condition while (true) { var parentA = a["return"]; if (parentA === null) { // We're at the root. break; } var parentB = parentA.alternate; if (parentB === null) { // There is no alternate. This is an unusual case. Currently, it only // happens when a Suspense component is hidden. An extra fragment fiber // is inserted in between the Suspense fiber and its children. Skip // over this extra fragment fiber and proceed to the next parent. var nextParent = parentA["return"]; if (nextParent !== null) { a = b = nextParent; continue; } // If there's no parent, we're at the root. break; } // If both copies of the parent fiber point to the same child, we can // assume that the child is current. This happens when we bailout on low // priority: the bailed out fiber's child reuses the current child. if (parentA.child === parentB.child) { var child = parentA.child; while (child) { if (child === a) { // We've determined that A is the current branch. return fiber; } if (child === b) { // We've determined that B is the current branch. return alternate; } child = child.sibling; } // We should never have an alternate for any mounting node. So the only // way this could possibly happen is if this was unmounted, if at all. throw new Error('Unable to find node on an unmounted component.'); } if (a["return"] !== b["return"]) { // The return pointer of A and the return pointer of B point to different // fibers. We assume that return pointers never criss-cross, so A must // belong to the child set of A.return, and B must belong to the child // set of B.return. a = parentA; b = parentB; } else { // The return pointers point to the same fiber. We'll have to use the // default, slow path: scan the child sets of each parent alternate to see // which child belongs to which set. // // Search parent A's child set var didFindChild = false; var _child = parentA.child; while (_child) { if (_child === a) { didFindChild = true; a = parentA; b = parentB; break; } if (_child === b) { didFindChild = true; b = parentA; a = parentB; break; } _child = _child.sibling; } if (!didFindChild) { // Search parent B's child set _child = parentB.child; while (_child) { if (_child === a) { didFindChild = true; a = parentB; b = parentA; break; } if (_child === b) { didFindChild = true; b = parentB; a = parentA; break; } _child = _child.sibling; } if (!didFindChild) { throw new Error('Child was not found in either parent set. This indicates a bug ' + 'in React related to the return pointer. Please file an issue.'); } } } if (a.alternate !== b) { throw new Error("Return fibers should always be each others' alternates. " + 'This error is likely caused by a bug in React. Please file an issue.'); } } // If the root is not a host container, we're in a disconnected tree. I.e. // unmounted. if (a.tag !== HostRoot) { throw new Error('Unable to find node on an unmounted component.'); } if (((_a$stateNode = a.stateNode) === null || _a$stateNode === void 0 ? void 0 : _a$stateNode.current) === a) { // We've determined that A is the current branch. return fiber; } // Otherwise B has to be current branch. return alternate; } module.exports = findCurrentFiberUsingSlowPath; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["HostRoot","Placement","Hydrating","NoFlags","getNearestMountedFiber","fiber","node","nearestMounted","alternate","nextNode","flags","tag","findCurrentFiberUsingSlowPath","Error","a","b","parentA","parentB","nextParent","child","sibling","didFindChild","stateNode","current","module","exports"],"sources":["../src/findCurrentFiberUsingSlowPath.js"],"sourcesContent":["// Extracted from https://github.com/facebook/react/blob/a724a3b578dce77d427bef313102a4d0e978d9b4/packages/react-reconciler/src/ReactFiberTreeReflection.js\n\nconst HostRoot = 3;\n\nconst Placement = 0b0000000000000000000000010;\nconst Hydrating = 0b0000000000001000000000000;\nconst NoFlags = 0b0000000000000000000000000;\n\nfunction getNearestMountedFiber(fiber) {\n  let node = fiber;\n  let nearestMounted = fiber;\n  if (!fiber.alternate) {\n    // If there is no alternate, this might be a new tree that isn't inserted\n    // yet. If it is, then it will have a pending insertion effect on it.\n    let nextNode = node;\n    do {\n      node = nextNode;\n      if ((node.flags & (Placement | Hydrating)) !== NoFlags) {\n        // This is an insertion or in-progress hydration. The nearest possible\n        // mounted fiber is the parent but we need to continue to figure out\n        // if that one is still mounted.\n        nearestMounted = node.return;\n      }\n      nextNode = node.return;\n    } while (nextNode);\n  } else {\n    while (node.return) {\n      node = node.return;\n    }\n  }\n  if (node.tag === HostRoot) {\n    // TODO: Check if this was a nested HostRoot when used with\n    // renderContainerIntoSubtree.\n    return nearestMounted;\n  }\n  // If we didn't hit the root, that means that we're in an disconnected tree\n  // that has been unmounted.\n  return null;\n}\n\nfunction findCurrentFiberUsingSlowPath(fiber) {\n  const alternate = fiber.alternate;\n  if (!alternate) {\n    // If there is no alternate, then we only need to check if it is mounted.\n    const nearestMounted = getNearestMountedFiber(fiber);\n\n    if (nearestMounted === null) {\n      throw new Error('Unable to find node on an unmounted component.');\n    }\n\n    if (nearestMounted !== fiber) {\n      return null;\n    }\n    return fiber;\n  }\n  // If we have two possible branches, we'll walk backwards up to the root\n  // to see what path the root points to. On the way we may hit one of the\n  // special cases and we'll deal with them.\n  let a = fiber;\n  let b = alternate;\n  // eslint-disable-next-line no-constant-condition\n  while (true) {\n    const parentA = a.return;\n    if (parentA === null) {\n      // We're at the root.\n      break;\n    }\n    const parentB = parentA.alternate;\n    if (parentB === null) {\n      // There is no alternate. This is an unusual case. Currently, it only\n      // happens when a Suspense component is hidden. An extra fragment fiber\n      // is inserted in between the Suspense fiber and its children. Skip\n      // over this extra fragment fiber and proceed to the next parent.\n      const nextParent = parentA.return;\n      if (nextParent !== null) {\n        a = b = nextParent;\n        continue;\n      }\n      // If there's no parent, we're at the root.\n      break;\n    }\n\n    // If both copies of the parent fiber point to the same child, we can\n    // assume that the child is current. This happens when we bailout on low\n    // priority: the bailed out fiber's child reuses the current child.\n    if (parentA.child === parentB.child) {\n      let child = parentA.child;\n      while (child) {\n        if (child === a) {\n          // We've determined that A is the current branch.\n          return fiber;\n        }\n        if (child === b) {\n          // We've determined that B is the current branch.\n          return alternate;\n        }\n        child = child.sibling;\n      }\n\n      // We should never have an alternate for any mounting node. So the only\n      // way this could possibly happen is if this was unmounted, if at all.\n      throw new Error('Unable to find node on an unmounted component.');\n    }\n\n    if (a.return !== b.return) {\n      // The return pointer of A and the return pointer of B point to different\n      // fibers. We assume that return pointers never criss-cross, so A must\n      // belong to the child set of A.return, and B must belong to the child\n      // set of B.return.\n      a = parentA;\n      b = parentB;\n    } else {\n      // The return pointers point to the same fiber. We'll have to use the\n      // default, slow path: scan the child sets of each parent alternate to see\n      // which child belongs to which set.\n      //\n      // Search parent A's child set\n      let didFindChild = false;\n      let child = parentA.child;\n      while (child) {\n        if (child === a) {\n          didFindChild = true;\n          a = parentA;\n          b = parentB;\n          break;\n        }\n        if (child === b) {\n          didFindChild = true;\n          b = parentA;\n          a = parentB;\n          break;\n        }\n        child = child.sibling;\n      }\n      if (!didFindChild) {\n        // Search parent B's child set\n        child = parentB.child;\n        while (child) {\n          if (child === a) {\n            didFindChild = true;\n            a = parentB;\n            b = parentA;\n            break;\n          }\n          if (child === b) {\n            didFindChild = true;\n            b = parentB;\n            a = parentA;\n            break;\n          }\n          child = child.sibling;\n        }\n\n        if (!didFindChild) {\n          throw new Error(\n            'Child was not found in either parent set. This indicates a bug ' +\n              'in React related to the return pointer. Please file an issue.',\n          );\n        }\n      }\n    }\n\n    if (a.alternate !== b) {\n      throw new Error(\n        \"Return fibers should always be each others' alternates. \" +\n          'This error is likely caused by a bug in React. Please file an issue.',\n      );\n    }\n  }\n\n  // If the root is not a host container, we're in a disconnected tree. I.e.\n  // unmounted.\n  if (a.tag !== HostRoot) {\n    throw new Error('Unable to find node on an unmounted component.');\n  }\n\n  if (a.stateNode?.current === a) {\n    // We've determined that A is the current branch.\n    return fiber;\n  }\n  // Otherwise B has to be current branch.\n  return alternate;\n}\n\nmodule.exports = findCurrentFiberUsingSlowPath;\n"],"mappings":"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"} //# sourceMappingURL=findCurrentFiberUsingSlowPath.js.map