diff --git a/mesh_snap_utilities_line/op_line.py b/mesh_snap_utilities_line/op_line.py
index 0444f0e2978a5b5952f96654bef5b514bd63ad50..eacc551be20a947c98660b1fadb975dfec77ad88 100644
--- a/mesh_snap_utilities_line/op_line.py
+++ b/mesh_snap_utilities_line/op_line.py
@@ -170,8 +170,28 @@ def make_line(self, bm_geom, location):
                     break
 
             ed_list.update(get_loose_linked_edges(v2))
+            ed_list = list(ed_list)
+
+            # WORKAROUND: `edgenet_fill` only works with loose edges or boundary
+            # edges, so remove the other edges and create temporary elements to
+            # replace them.
+            targetmap = {}
+            ed_new = []
+            for edge in ed_list:
+                if not edge.is_wire and not edge.is_boundary:
+                    v1, v2 = edge.verts
+                    tmp_vert = bm.verts.new(v2.co)
+                    e1 = bm.edges.new([v1, tmp_vert])
+                    e2 = bm.edges.new([tmp_vert, v2])
+                    ed_list.remove(edge)
+                    ed_new.append(e1)
+                    ed_new.append(e2)
+                    targetmap[tmp_vert] = v2
+
+            bmesh.ops.edgenet_fill(bm, edges=ed_list + ed_new)
+            if targetmap:
+                bmesh.ops.weld_verts(bm, targetmap=targetmap)
 
-            bmesh.ops.edgenet_fill(bm, edges=list(ed_list))
             update_edit_mesh = True
             # print('face created')