main: Copy cmd line args and print them
[src/agl-compositor.git] / src / layout.c
index dd7e75f..4ffcb16 100644 (file)
@@ -217,8 +217,7 @@ ivi_layout_activate_complete(struct ivi_output *output,
        weston_layer_entry_insert(&ivi->normal.view_list, &view->layer_link);
        weston_view_update_transform(view);
 
-       /* force repaint of the entire output */
-       weston_output_damage(output->output);
+       weston_view_damage_below(view);
 
        /*
         * the 'remote' role now makes use of this part so make sure we don't
@@ -241,6 +240,9 @@ ivi_layout_find_with_app_id(const char *app_id, struct ivi_compositor *ivi)
 {
        struct ivi_output *out;
 
+       if (!app_id)
+               return NULL;
+
        wl_list_for_each(out, &ivi->outputs, link) {
                if (!out->app_id)
                        continue;
@@ -325,6 +327,12 @@ ivi_layout_desktop_committed(struct ivi_surface *surf)
                        return;
                }
 
+               if (!surf->ivi->activate_by_default) {
+                       weston_log("Refusing to activate surface role %d, app_id %s\n",
+                                       surf->role, app_id);
+                       return;
+               }
+
                /* use the output of the bg to activate the app on start-up by
                 * default */
                if (surf->view && r_output) {
@@ -495,9 +503,7 @@ ivi_layout_split_committed(struct ivi_surface *surface)
 
        switch (surface->role) {
        case IVI_SURFACE_ROLE_SPLIT_V:
-               if (geom.width == woutput->width &&
-                   geom.height == woutput->height)
-                       geom.width = (output->area.width / 2);
+               geom.width = (output->area.width / 2);
 
                x += woutput->width - geom.width;
                output->area.width -= geom.width;
@@ -508,9 +514,7 @@ ivi_layout_split_committed(struct ivi_surface *surface)
 
                break;
        case IVI_SURFACE_ROLE_SPLIT_H:
-               if (geom.width == woutput->width &&
-                   geom.height == woutput->height)
-                       geom.height = (output->area.height / 2);
+               geom.height = (output->area.height / 2);
 
                y = output->area.y;
                output->area.y += geom.height;
@@ -732,7 +736,6 @@ ivi_layout_activate_by_surf(struct ivi_output *output, struct ivi_surface *surf)
 
                weston_log("Placed app_id %s, type %s in hidden layer\n",
                                app_id, ivi_layout_get_surface_role_name(surf));
-               weston_output_damage(output->output);
        }
 }
 
@@ -742,6 +745,9 @@ ivi_layout_activate(struct ivi_output *output, const char *app_id)
        struct ivi_surface *surf;
        struct ivi_compositor *ivi = output->ivi;
 
+       if (!app_id)
+               return;
+
        surf = ivi_find_app(ivi, app_id);
        if (!surf)
                return;
@@ -795,6 +801,9 @@ ivi_layout_deactivate(struct ivi_compositor *ivi, const char *app_id)
        struct ivi_output *ivi_output;
        struct ivi_policy *policy = ivi->policy;
 
+       if (!app_id)
+               return;
+
        surf = ivi_find_app(ivi, app_id);
        if (!surf)
                return;
@@ -823,7 +832,8 @@ ivi_layout_deactivate(struct ivi_compositor *ivi, const char *app_id)
                                view->surface->is_mapped = false;
 
                                weston_layer_entry_remove(&view->layer_link);
-                               weston_output_damage(ivi_output->output);
+                               weston_view_damage_below(view);
+                               ivi_output->active = NULL;
                        }
                } else {
                        struct weston_desktop_surface *dsurface;