@ -199,6 +199,7 @@ static void createFallbackDecoration(_GLFWdecorationWayland* decoration, 
			
		
	
		
		
			
				
					
					                                     int  width ,  int  height )                                       int  width ,  int  height )   
			
		
	
		
		
			
				
					
					{ {  
			
		
	
		
		
			
				
					
					    decoration - > surface  =  wl_compositor_create_surface ( _glfw . wl . compositor ) ;      decoration - > surface  =  wl_compositor_create_surface ( _glfw . wl . compositor ) ;   
			
		
	
		
		
			
				
					
					    wl_proxy_set_tag ( ( struct  wl_proxy * )  decoration - > surface ,  & _glfw . wl . tag ) ;   
			
		
	
		
		
			
				
					
					    decoration - > subsurface  =      decoration - > subsurface  =   
			
		
	
		
		
			
				
					
					        wl_subcompositor_get_subsurface ( _glfw . wl . subcompositor ,          wl_subcompositor_get_subsurface ( _glfw . wl . subcompositor ,   
			
		
	
		
		
			
				
					
					                                        decoration - > surface ,  parent ) ;                                          decoration - > surface ,  parent ) ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -371,6 +372,9 @@ static void surfaceHandleEnter(void* userData, 
			
		
	
		
		
			
				
					
					                               struct  wl_surface *  surface ,                                 struct  wl_surface *  surface ,   
			
		
	
		
		
			
				
					
					                               struct  wl_output *  output )                                 struct  wl_output *  output )   
			
		
	
		
		
			
				
					
					{ {  
			
		
	
		
		
			
				
					
					    if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  output )  ! =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    _GLFWwindow *  window  =  userData ;      _GLFWwindow *  window  =  userData ;   
			
		
	
		
		
			
				
					
					    _GLFWmonitor *  monitor  =  wl_output_get_user_data ( output ) ;      _GLFWmonitor *  monitor  =  wl_output_get_user_data ( output ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -391,6 +395,9 @@ static void surfaceHandleLeave(void* userData, 
			
		
	
		
		
			
				
					
					                               struct  wl_surface *  surface ,                                 struct  wl_surface *  surface ,   
			
		
	
		
		
			
				
					
					                               struct  wl_output *  output )                                 struct  wl_output *  output )   
			
		
	
		
		
			
				
					
					{ {  
			
		
	
		
		
			
				
					
					    if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  output )  ! =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    _GLFWwindow *  window  =  userData ;      _GLFWwindow *  window  =  userData ;   
			
		
	
		
		
			
				
					
					    _GLFWmonitor *  monitor  =  wl_output_get_user_data ( output ) ;      _GLFWmonitor *  monitor  =  wl_output_get_user_data ( output ) ;   
			
		
	
		
		
			
				
					
					    GLFWbool  found  =  GLFW_FALSE ;      GLFWbool  found  =  GLFW_FALSE ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -729,6 +736,7 @@ static GLFWbool createNativeSurface(_GLFWwindow* window, 
			
		
	
		
		
			
				
					
					        return  GLFW_FALSE ;          return  GLFW_FALSE ;   
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    wl_proxy_set_tag ( ( struct  wl_proxy * )  window - > wl . surface ,  & _glfw . wl . tag ) ;   
			
		
	
		
		
			
				
					
					    wl_surface_add_listener ( window - > wl . surface ,      wl_surface_add_listener ( window - > wl . surface ,   
			
		
	
		
		
			
				
					
					                            & surfaceListener ,                              & surfaceListener ,   
			
		
	
		
		
			
				
					
					                            window ) ;                              window ) ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1063,6 +1071,9 @@ static void pointerHandleEnter(void* userData, 
			
		
	
		
		
			
				
					
					    if  ( ! surface )      if  ( ! surface )   
			
		
	
		
		
			
				
					
					        return ;          return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  surface )  ! =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    _GLFWdecorationSideWayland  focus  =  mainWindow ;      _GLFWdecorationSideWayland  focus  =  mainWindow ;   
			
		
	
		
		
			
				
					
					    _GLFWwindow *  window  =  wl_surface_get_user_data ( surface ) ;      _GLFWwindow *  window  =  wl_surface_get_user_data ( surface ) ;   
			
		
	
		
		
			
				
					
					    if  ( ! window )      if  ( ! window )   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1088,8 +1099,13 @@ static void pointerHandleLeave(void* userData, 
			
		
	
		
		
			
				
					
					                               uint32_t  serial ,                                 uint32_t  serial ,   
			
		
	
		
		
			
				
					
					                               struct  wl_surface *  surface )                                 struct  wl_surface *  surface )   
			
		
	
		
		
			
				
					
					{ {  
			
		
	
		
		
			
				
					
					    _GLFWwindow *  window  =  _glfw . wl . pointerFocus ;      if  ( ! surface )   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  surface )  ! =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    _GLFWwindow *  window  =  _glfw . wl . pointerFocus ;   
			
		
	
		
		
			
				
					
					    if  ( ! window )      if  ( ! window )   
			
		
	
		
		
			
				
					
					        return ;          return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1681,7 +1697,10 @@ static void dataDeviceHandleEnter(void* userData, 
			
		
	
		
		
			
				
					
					            _GLFWwindow *  window  =  NULL ;              _GLFWwindow *  window  =  NULL ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					            if  ( surface )              if  ( surface )   
			
		
	
		
		
			
				
					
					            {   
			
		
	
		
		
			
				
					
					                if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  surface )  = =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					                    window  =  wl_surface_get_user_data ( surface ) ;                      window  =  wl_surface_get_user_data ( surface ) ;   
			
		
	
		
		
			
				
					
					            }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					            if  ( window  & &  _glfw . wl . offers [ i ] . text_uri_list )              if  ( window  & &  _glfw . wl . offers [ i ] . text_uri_list )   
			
		
	
		
		
			
				
					
					            {              {   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1696,6 +1715,9 @@ static void dataDeviceHandleEnter(void* userData, 
			
		
	
		
		
			
				
					
					        }          }   
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( wl_proxy_get_tag ( ( struct  wl_proxy * )  surface )  ! =  & _glfw . wl . tag )   
			
		
	
		
		
			
				
					
					        return ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( _glfw . wl . dragOffer )      if  ( _glfw . wl . dragOffer )   
			
		
	
		
		
			
				
					
					        wl_data_offer_accept ( offer ,  serial ,  " text/uri-list " ) ;          wl_data_offer_accept ( offer ,  serial ,  " text/uri-list " ) ;   
			
		
	
		
		
			
				
					
					    else      else