]> git.sur5r.net Git - i3/i3/log
i3/i3
7 years agoAdd SWAP util macro
Orestis Floros [Sat, 16 Sep 2017 10:43:28 +0000 (13:43 +0300)]
Add SWAP util macro

7 years agoMerge pull request #2887 from orestisf1993/next
Ingo Bürk [Fri, 15 Sep 2017 19:26:35 +0000 (21:26 +0200)]
Merge pull request #2887 from orestisf1993/next

Allow assign to workspace by number

7 years agoMerge pull request #2950 from CyberShadow/pull-20170914-153533
Michael Stapelberg [Fri, 15 Sep 2017 09:31:33 +0000 (11:31 +0200)]
Merge pull request #2950 from CyberShadow/pull-20170914-153533

Fix erratic behavior with single container child jumping outputs

7 years agoFix erratic behavior with single container child jumping outputs 2950/head
Vladimir Panteleev [Thu, 14 Sep 2017 15:41:48 +0000 (15:41 +0000)]
Fix erratic behavior with single container child jumping outputs

This fixes a regression introduced in commit
4e88c10564ca5366c2578908f62ec56625a26718: when attempting to move the
single child of a container in the direction of another output, i3
would move the window to the output, despite the window not being at
the edge of its output, instead of moving it to its parent container.

The bug occurred because the check for moving containers across
outputs with non-default workspace layouts (issue #1603) did not
actually verify that the moved window lies at the edge of the
workspace, despite what its comment said.

Fixes issue #2466.

7 years agoUse numeric comparison in sort for $displaynum (#2952)
Orestis [Fri, 15 Sep 2017 09:21:35 +0000 (12:21 +0300)]
Use numeric comparison in sort for $displaynum (#2952)

Eg in the case of sockets:
- X0
- X99
- X100

X99 would be picked instead of X100.

7 years agoAllow assign to workspace by number 2887/head
Orestis Floros [Mon, 28 Aug 2017 02:14:03 +0000 (05:14 +0300)]
Allow assign to workspace by number

Makes "assign [<criteria>] workspace number <number>" work in the same
manner as "move to workspace number <number>" instead of assigning the
window to a workspace named "number <number>".

config.spec is modified to expect a 'number' string and an extra
argument is used in cfg_assign.

For workspaces that don't exist yet, workspace_get is used as a
fallback. This also allows the user to assign to "<number> <workspace>"
eg "2: work" and the full name will be used if workspace number 2
doesn't exist yet.

Fixes #2590.

7 years agoFix typo in con_parent_with_orientation description
Vladimir Panteleev [Thu, 14 Sep 2017 15:51:49 +0000 (15:51 +0000)]
Fix typo in con_parent_with_orientation description

7 years agoAdd -name argument for Xephyr (#2937)
Orestis [Thu, 14 Sep 2017 20:10:16 +0000 (23:10 +0300)]
Add -name argument for Xephyr (#2937)

This way you can assign the test windows to an empty workspace to avoid
interacting with them (when xvfb-run is not an option):
assign [instance="i3test"] workspace testing

7 years agoMerge pull request #2945 from stapelberg/i3-config
Michael Stapelberg [Thu, 14 Sep 2017 20:08:36 +0000 (22:08 +0200)]
Merge pull request #2945 from stapelberg/i3-config

simplify tests which use launch_with_config precisely once

7 years agotests: unflake tests by not starting i3bar 2945/head
Michael Stapelberg [Thu, 14 Sep 2017 11:35:26 +0000 (13:35 +0200)]
tests: unflake tests by not starting i3bar

7 years agotests: remove the (broken) exit_gracefully check
Michael Stapelberg [Thu, 14 Sep 2017 09:30:58 +0000 (11:30 +0200)]
tests: remove the (broken) exit_gracefully check

I previously tried to fix the check, but could only come up with a fix which
required removing our module pre-loading, which makes the tests considerably
more expensive. Instead, let’s just remove the check.

7 years agotests: use i3_config arg instead of precisely one launch_with_config
Michael Stapelberg [Thu, 14 Sep 2017 10:30:42 +0000 (12:30 +0200)]
tests: use i3_config arg instead of precisely one launch_with_config

This way, tests are shorter, and i3test’s invocation of launch_with_config
parallelizes work better, using dont_block => 1.

7 years agoi3test::XTEST: don’t “use i3test” to avoid clobbering state
Michael Stapelberg [Thu, 14 Sep 2017 09:44:49 +0000 (11:44 +0200)]
i3test::XTEST: don’t “use i3test” to avoid clobbering state

Before this commit, the $i3_autostart variable was accidentally overridden.

7 years agoReorder tests to not use the same number (#2947)
Michael Stapelberg [Thu, 14 Sep 2017 15:49:02 +0000 (17:49 +0200)]
Reorder tests to not use the same number (#2947)

Distinct numbers make re-running individual tests easier by helping with
tab-completion.

Completeness verified using:
% for i in $(seq 0 600)
do
  files=$(ls testcases/t/$(printf "%03d" $i)-*.t 2>&- | wc -l)
  [ "$files" != "0" ] && [ "$files" != "1" ] && echo "clash: $i"
done

7 years agotests: unflake t/257-keypress-group1-fallback.t (#2946)
Michael Stapelberg [Thu, 14 Sep 2017 15:48:37 +0000 (17:48 +0200)]
tests: unflake t/257-keypress-group1-fallback.t (#2946)

fixes #2944

7 years agotravis: install xrandr in Docker container for t/533-randr15.t (#2949)
Michael Stapelberg [Thu, 14 Sep 2017 15:48:22 +0000 (17:48 +0200)]
travis: install xrandr in Docker container for t/533-randr15.t (#2949)

7 years agoMerge pull request #2942 from stapelberg/append
Michael Stapelberg [Wed, 13 Sep 2017 16:38:47 +0000 (18:38 +0200)]
Merge pull request #2942 from stapelberg/append

Improve append_layout’s invalid JSON handling

7 years agoAdd .editorconfig (see editorconfig.org) (#2943)
Michael Stapelberg [Wed, 13 Sep 2017 16:38:27 +0000 (18:38 +0200)]
Add .editorconfig (see editorconfig.org) (#2943)

This file uses the same settings which we currently have in our vim modeline,
but can be picked up by many different editors without having to add and
maintain editor-specific modelines in all of our source files.

7 years agovalidate JSON before loading 2942/head
Michael Stapelberg [Wed, 13 Sep 2017 15:14:51 +0000 (17:14 +0200)]
validate JSON before loading

This commit also introduces slurp() which reads a file in its entirety. Using
this function instead of doing IO in the functions in load_layout.c again and
again makes the code cleaner (fixing at least two memory leaks) and avoids
re-reading the same file 3 times.

related to #2755

7 years agoAnyEvent-I3: use Carp for easier debugging (includes stacktraces)
Michael Stapelberg [Wed, 13 Sep 2017 14:39:44 +0000 (16:39 +0200)]
AnyEvent-I3: use Carp for easier debugging (includes stacktraces)

7 years agoBugfix: free incomplete containers when JSON parsing fails
Michael Stapelberg [Wed, 13 Sep 2017 14:39:13 +0000 (16:39 +0200)]
Bugfix: free incomplete containers when JSON parsing fails

related to #2755

7 years agoMerge pull request #2935 from orestisf1993/issue-2934
Michael Stapelberg [Wed, 13 Sep 2017 13:07:21 +0000 (15:07 +0200)]
Merge pull request #2935 from orestisf1993/issue-2934

Make sure that parse_config input terminates with '\0'

7 years agoscalloc parse_config input to make sure it terminates with '\0' 2935/head
Orestis Floros [Tue, 12 Sep 2017 09:29:01 +0000 (12:29 +0300)]
scalloc parse_config input to make sure it terminates with '\0'

Otherwise strchr() can crash for files that don't end with '\n' because
it won't find a null char to terminate at.

Fixes #2934

7 years agoDon't insert newline at end of config with launch_with_config
Orestis Floros [Wed, 13 Sep 2017 10:32:12 +0000 (13:32 +0300)]
Don't insert newline at end of config with launch_with_config

7 years agoMerge pull request #2920 from CyberShadow/monitor-output-names
Michael Stapelberg [Wed, 13 Sep 2017 08:58:38 +0000 (10:58 +0200)]
Merge pull request #2920 from CyberShadow/monitor-output-names

Consider RandR 1.5's monitors' output names in addition to monitor names

7 years agodocs/userguide: Document that i3 can accept RandR output names 2920/head
Vladimir Panteleev [Tue, 12 Sep 2017 09:27:49 +0000 (09:27 +0000)]
docs/userguide: Document that i3 can accept RandR output names

7 years ago533-randr15.t: Add test for bar output name canonicalization
Vladimir Panteleev [Tue, 12 Sep 2017 09:18:40 +0000 (09:18 +0000)]
533-randr15.t: Add test for bar output name canonicalization

7 years ago533-randr15.t: Stop hard-coding the output name
Vladimir Panteleev [Tue, 12 Sep 2017 08:50:40 +0000 (08:50 +0000)]
533-randr15.t: Stop hard-coding the output name

Refactor away all mentions of DP3.

7 years ago533-randr15.t: Add a fake output connected to the fake monitor
Vladimir Panteleev [Tue, 12 Sep 2017 08:42:46 +0000 (08:42 +0000)]
533-randr15.t: Add a fake output connected to the fake monitor

Add an output ID to the simulated RRGetMonitors reply, then add a
simulated RRGetOutputInfo reply describing the added output.

7 years agotestcases/lib: Add inject_randr15_outputinfo argument
Vladimir Panteleev [Tue, 12 Sep 2017 08:41:00 +0000 (08:41 +0000)]
testcases/lib: Add inject_randr15_outputinfo argument

Allow tests to specify a file name for inject_randr15's
--getoutputinfo_reply command-line parameter.

7 years agoinject_randr1.5: Intercept X11 error responses in addition to replies
Vladimir Panteleev [Tue, 12 Sep 2017 08:39:15 +0000 (08:39 +0000)]
inject_randr1.5: Intercept X11 error responses in addition to replies

Allow clients to send garbage to the server, then intercept the
server's error response and substitute it with the supplied simulated
reply data.

7 years agoinject_randr1.5: Add RRGetOutputInfo reply injection
Vladimir Panteleev [Tue, 12 Sep 2017 07:03:20 +0000 (07:03 +0000)]
inject_randr1.5: Add RRGetOutputInfo reply injection

Add a --getoutputinfo_reply switch to indicate a filename containing
the RRGetOutputInfo reply data to inject.

7 years agoinject_randr1.5: Refactor reading and storing reply buffer to a struct
Vladimir Panteleev [Tue, 12 Sep 2017 06:58:29 +0000 (06:58 +0000)]
inject_randr1.5: Refactor reading and storing reply buffer to a struct

Allows easier introduction of additional reply buffers in upcoming
changes.

7 years agoipc: Canonicalize output names in bar configuration
Vladimir Panteleev [Mon, 11 Sep 2017 11:15:56 +0000 (11:15 +0000)]
ipc: Canonicalize output names in bar configuration

Convert the output names specified in the "output" and "tray_output"
fields in bar blocks in i3's configuration to the referred output's
primary name. This allows specifying names other than the primary
output's name in the given fields without changing the IPC protocol.

7 years agorandr: Look up alternative output names when searching outputs
Vladimir Panteleev [Sat, 9 Sep 2017 09:23:50 +0000 (09:23 +0000)]
randr: Look up alternative output names when searching outputs

Update get_output_by_name to look at all additional names added by the
change in the previous commit, not just the primary one.

7 years agorandr: Register monitors' output names as additional i3 output names
Vladimir Panteleev [Sat, 9 Sep 2017 09:00:22 +0000 (09:00 +0000)]
randr: Register monitors' output names as additional i3 output names

In addition to the name of the monitor itself (which is still used as
the i3 output's primary name), register RandR output names associated
with the RandR monitor as alternative i3 output names.

7 years agoStore output names as a linked list
Vladimir Panteleev [Sat, 9 Sep 2017 07:37:37 +0000 (07:37 +0000)]
Store output names as a linked list

Currently, only one name is ever added, and only the first name is
ever accessed; actually using the capability to store and access
multiple names comes in the following commits.

7 years agoIntroduce output_primary_name function
Vladimir Panteleev [Sat, 9 Sep 2017 07:18:29 +0000 (07:18 +0000)]
Introduce output_primary_name function

Currently simply returns output->name, but this will make it easier to
change how output names are stored in the following commits.

Also replace reading output->name with invocations of
output_primary_name. Code which writes output->name is unchanged. Done
using a mostly mechanical replacement of output->name to
output_primary_name(output).

7 years agotestsuite: install Module::Install so that AnyEvent-I3/Makefile.PL works (#2940)
Michael Stapelberg [Tue, 12 Sep 2017 20:16:36 +0000 (22:16 +0200)]
testsuite: install Module::Install so that AnyEvent-I3/Makefile.PL works (#2940)

As per https://perlmaven.com/cant-locate-inc-module-install-in-inc, the inc/
directory should not be under version control.

fixes #2914

7 years agoFix userguide bug (#2932)
Orestis [Mon, 11 Sep 2017 19:31:29 +0000 (22:31 +0300)]
Fix userguide bug (#2932)

Fixes #2931

7 years agoMerge pull request #2928 from CyberShadow/pull-20170911-130032
Ingo Bürk [Mon, 11 Sep 2017 18:49:47 +0000 (20:49 +0200)]
Merge pull request #2928 from CyberShadow/pull-20170911-130032

docs/hacking-howto: Promote "Using git / sending patches" section

7 years agodocs/hacking-howto: Update section topology 2928/head
Vladimir Panteleev [Mon, 11 Sep 2017 13:09:25 +0000 (13:09 +0000)]
docs/hacking-howto: Update section topology

- Promote the "How to build?" sub-section to a top-level
  section ("Building i3")

- Convert the "Introduction" sub-section as the intro to the remaining
  contents of the "Using git / sending patches" section

- Keep "Which branch to use?" as a level-3 sub-section, thus making it
  a sub-section of what used to be the "Introduction" sub-section.

7 years agodocs/hacking-howto: Promote "How to build?" sub-section
Vladimir Panteleev [Mon, 11 Sep 2017 13:06:40 +0000 (13:06 +0000)]
docs/hacking-howto: Promote "How to build?" sub-section

Move the "How to build?" sub-section to the top of its parent section.

7 years agodocs/hacking-howto: Promote "Using git / sending patches" section
Vladimir Panteleev [Mon, 11 Sep 2017 13:04:58 +0000 (13:04 +0000)]
docs/hacking-howto: Promote "Using git / sending patches" section

Move the contents of the "Using git / sending patches" section to the
top of the document.

7 years agoMerge pull request #2926 from stapelberg/unflake-tests
Michael Stapelberg [Sun, 10 Sep 2017 20:08:05 +0000 (22:08 +0200)]
Merge pull request #2926 from stapelberg/unflake-tests

Unflake tests

7 years agotests: run 533-randr15.t at the very end 2926/head
Michael Stapelberg [Sun, 10 Sep 2017 18:05:55 +0000 (20:05 +0200)]
tests: run 533-randr15.t at the very end

The test runs `xrandr setmonitor`, which will otherwise affect any test
scheduled after 533-randr15.t, causing flakyness in t/217-NET_CURRENT_DESKTOP.t
for example.

7 years agotests: unflake t/263-edge-borders.t
Michael Stapelberg [Sun, 10 Sep 2017 18:06:49 +0000 (20:06 +0200)]
tests: unflake t/263-edge-borders.t

7 years agotests: re-seed random number generator in workers
Michael Stapelberg [Sun, 10 Sep 2017 17:41:49 +0000 (19:41 +0200)]
tests: re-seed random number generator in workers

7 years agoRevert "Use OVER operator for drawing text (#2908)" (#2925)
Ingo Bürk [Sun, 10 Sep 2017 15:03:09 +0000 (17:03 +0200)]
Revert "Use OVER operator for drawing text (#2908)" (#2925)

This reverts commit 16160462a30f186f5b72bb551ba2188670d4e45c.

7 years agoMerge pull request #2923 from stapelberg/tests-split
Michael Stapelberg [Sun, 10 Sep 2017 11:41:46 +0000 (13:41 +0200)]
Merge pull request #2923 from stapelberg/tests-split

Testsuite: avoid starting new i3 instances where possible

7 years agodocs/testsuite: Correct Xephyr package name on Arch Linux (#2913)
Vladimir Panteleev [Sun, 10 Sep 2017 11:02:10 +0000 (11:02 +0000)]
docs/testsuite: Correct Xephyr package name on Arch Linux (#2913)

The package is called `xorg-server-xephyr`, not `xorg-xserver-xephyr`.

7 years agoKill windows between tests 2923/head
Michael Stapelberg [Sun, 10 Sep 2017 09:31:10 +0000 (11:31 +0200)]
Kill windows between tests

7 years agoi3test: add kill_all_windows convenience function
Michael Stapelberg [Sun, 10 Sep 2017 09:30:56 +0000 (11:30 +0200)]
i3test: add kill_all_windows convenience function

7 years agotestcases/Makefile.PL: tell MakeMaker this is a pure-Perl distribution (#2922)
Michael Stapelberg [Sun, 10 Sep 2017 09:25:43 +0000 (11:25 +0200)]
testcases/Makefile.PL: tell MakeMaker this is a pure-Perl distribution (#2922)

fixes #2914

7 years agoAdd README.md (#2910)
Vladimir Panteleev [Sun, 10 Sep 2017 05:43:53 +0000 (05:43 +0000)]
Add README.md (#2910)

7 years ago529-net-wm-desktop: avoid timeout, avoid restarts, split
Michael Stapelberg [Sat, 9 Sep 2017 16:39:56 +0000 (18:39 +0200)]
529-net-wm-desktop: avoid timeout, avoid restarts, split

This shaves off almost half a second of the wall-clock time (from 5.9s to 5.6s).

7 years agotravis: remove clang-analyze (#2917)
Michael Stapelberg [Sat, 9 Sep 2017 16:30:17 +0000 (18:30 +0200)]
travis: remove clang-analyze (#2917)

• The output currently contains a large number of false-positives and — AFAICT —
  no actual issues.

• Upstream shows little interest in addressing the long-standing issues with the
  TAILQ macros, so the false-positive situation probably won’t change soon:
  https://bugs.llvm.org/show_bug.cgi?id=18222

Currently, we largely spend travis CPU cycles on this, for no additional value.

7 years ago165-for_window: merge config and re-use i3 instance, split remainder
Michael Stapelberg [Sat, 9 Sep 2017 16:21:59 +0000 (18:21 +0200)]
165-for_window: merge config and re-use i3 instance, split remainder

This reduces total test wall-clock time by 1.5s (from 7.5s down to 5.9s).

7 years agot/265-swap: don’t start new i3 instances with the same config
Michael Stapelberg [Sat, 9 Sep 2017 15:50:23 +0000 (17:50 +0200)]
t/265-swap: don’t start new i3 instances with the same config

$config is never touched after being initially set up.
Not restarting i3 between each test case reduces the runtime of this test by an
order of magnitude.

7 years agoUse OVER operator for drawing text (#2908)
Jan Alexander Steffens [Sat, 9 Sep 2017 15:32:34 +0000 (17:32 +0200)]
Use OVER operator for drawing text (#2908)

For opaque text, SOURCE is not any different from OVER. However, when
drawing color glyphs (which consist of RGBA pixels instead of strokes)
SOURCE's handling of alpha is not what we want.

I stumbled across this because cairo 1.15.8 seems to clear the surface
before drawing color emoji if the operator is SOURCE, deleting every-
thing drawn before. Arguably, the area outside the glyph bounds should
not be touched, but even if this is a cairo bug the problem of alpha
within the glyph remains.

7 years agoAdd files generated by make check in AnyEvent-I3/ to .gitignore (#2915)
Orestis [Sat, 9 Sep 2017 12:47:32 +0000 (15:47 +0300)]
Add files generated by make check in AnyEvent-I3/ to .gitignore (#2915)

7 years agoInclude AnyEvent-I3 directory in dist tarballs (#2916)
Michael Stapelberg [Sat, 9 Sep 2017 12:22:16 +0000 (14:22 +0200)]
Include AnyEvent-I3 directory in dist tarballs (#2916)

fixes #2905

7 years agoMerge pull request #2911 from i3/asan
Michael Stapelberg [Sat, 9 Sep 2017 09:41:07 +0000 (11:41 +0200)]
Merge pull request #2911 from i3/asan

i3bar: ensure get_buffer does not leak memory

7 years agotravis: downgrade temporarily due to asan issue 2911/head
Michael Stapelberg [Sat, 9 Sep 2017 06:15:03 +0000 (08:15 +0200)]
travis: downgrade temporarily due to asan issue

fixes #2912

7 years agoi3bar: ensure get_buffer does not leak memory
Michael Stapelberg [Sat, 9 Sep 2017 04:56:50 +0000 (06:56 +0200)]
i3bar: ensure get_buffer does not leak memory

This fixes an AddressSanitizer warning which recently popped up.

related to #2907

7 years agoMerge pull request #2901 from orestisf1993/issue-2900
Michael Stapelberg [Thu, 7 Sep 2017 12:55:37 +0000 (14:55 +0200)]
Merge pull request #2901 from orestisf1993/issue-2900

Set marks to NULL after freeing

7 years agoSet marks to NULL after freeing 2901/head
Orestis Floros [Thu, 7 Sep 2017 00:53:28 +0000 (03:53 +0300)]
Set marks to NULL after freeing

realloc() was being called on an already freed pointer.

Fixes #2900

7 years agoImprove 267-regress-mark-restart.t
Orestis Floros [Thu, 7 Sep 2017 01:19:57 +0000 (04:19 +0300)]
Improve 267-regress-mark-restart.t

Another window with a mark is needed for issue #2900.

7 years agoMerge pull request #2899 from orestisf1993/patch-1
Ingo Bürk [Wed, 6 Sep 2017 15:08:02 +0000 (17:08 +0200)]
Merge pull request #2899 from orestisf1993/patch-1

Fix typo in 265-swap.t

7 years agoFix typo in 265-swap.t 2899/head
Orestis [Wed, 6 Sep 2017 15:02:52 +0000 (18:02 +0300)]
Fix typo in 265-swap.t

7 years agoCheck if con_id exists in cmd_swap (#2898)
Orestis [Wed, 6 Sep 2017 05:34:14 +0000 (08:34 +0300)]
Check if con_id exists in cmd_swap (#2898)

Also adds some testcases for swap using con_id.

Fixes #2895

7 years agoInvert condition to log debug message in correct situation (#2896)
Ingo Bürk [Tue, 5 Sep 2017 07:01:53 +0000 (09:01 +0200)]
Invert condition to log debug message in correct situation (#2896)

7 years agoMerge pull request #2891 from hwangcc23/init-sigaction
Ingo Bürk [Mon, 4 Sep 2017 16:44:14 +0000 (18:44 +0200)]
Merge pull request #2891 from hwangcc23/init-sigaction

Properly initialize sigaction struct

7 years agoMerge pull request #2875 from botovq/next
Ingo Bürk [Mon, 4 Sep 2017 16:43:42 +0000 (18:43 +0200)]
Merge pull request #2875 from botovq/next

Avoid use of uninitialized in init_dpi_end

7 years agodebian: update changelog
Michael Stapelberg [Mon, 4 Sep 2017 06:21:06 +0000 (08:21 +0200)]
debian: update changelog

7 years agoMerge branch 'release-4.14'
Michael Stapelberg [Mon, 4 Sep 2017 05:53:39 +0000 (07:53 +0200)]
Merge branch 'release-4.14'

7 years agoSet non-git version to 4.14-non-git.
Michael Stapelberg [Mon, 4 Sep 2017 05:53:39 +0000 (07:53 +0200)]
Set non-git version to 4.14-non-git.

7 years agorelease i3 4.14 4.14
Michael Stapelberg [Mon, 4 Sep 2017 05:53:25 +0000 (07:53 +0200)]
release i3 4.14

7 years agoRevert "i3-nagbar: add button flag to execute action with /bin/sh directly" (#2893)
Michael Stapelberg [Thu, 31 Aug 2017 20:50:00 +0000 (22:50 +0200)]
Revert "i3-nagbar: add button flag to execute action with /bin/sh directly" (#2893)

7 years agoProperly initialize sigaction struct 2891/head
hwangcc23 [Thu, 31 Aug 2017 14:48:33 +0000 (22:48 +0800)]
Properly initialize sigaction struct

The code in handle_signal() wasn't clearing the struct sigaction before passing it to sigaction().
This meant that we would block a random set of signals while executing the default handler, or jump to the uninitialized __sa_sigaction__ (instead of sa_handler).
Initialize properly as we do in setup_signal_handler().

7 years agoRespect focus_on_window_activation for ConfigureRequests (#2889)
Michael Stapelberg [Mon, 28 Aug 2017 10:07:56 +0000 (12:07 +0200)]
Respect focus_on_window_activation for ConfigureRequests (#2889)

fixes #2873

7 years agoMerge pull request #2888 from stapelberg/leak
Michael Stapelberg [Mon, 28 Aug 2017 10:07:40 +0000 (12:07 +0200)]
Merge pull request #2888 from stapelberg/leak

Fix memory leak

7 years agoUpdate doc for dependency Module::Install (#2877)
Chih-Chyuan Hwang [Mon, 28 Aug 2017 07:43:42 +0000 (15:43 +0800)]
Update doc for dependency Module::Install (#2877)

After moving to AnyEvent-I3, a new testsuite dependency is introduced: Module::Install.
Update the doc for this.
See the issue #2876.

7 years agodo leak check before exiting 2888/head
Michael Stapelberg [Mon, 28 Aug 2017 07:23:42 +0000 (09:23 +0200)]
do leak check before exiting

related to #2541

7 years agoFix memleak: free regex when parsing fails
Michael Stapelberg [Mon, 28 Aug 2017 07:22:38 +0000 (09:22 +0200)]
Fix memleak: free regex when parsing fails

fixes #2541

7 years agoMerge pull request #2882 from jolange/dev
Ingo Bürk [Sat, 26 Aug 2017 09:38:06 +0000 (11:38 +0200)]
Merge pull request #2882 from jolange/dev

docs markup fixes

7 years agodocs markup fixes 2882/head
Johannes Lange [Mon, 5 Jun 2017 12:30:49 +0000 (14:30 +0200)]
docs markup fixes

7 years agoAvoid use of uninitialized in init_dpi_end 2875/head
Theo Buehler [Wed, 23 Aug 2017 13:48:58 +0000 (15:48 +0200)]
Avoid use of uninitialized in init_dpi_end

If conn == NULL or display == NULL, init_dpi() jumps to init_dpi_end
before (declaring and) initializing resource. In init_dpi_end, there
is a free(resource) call conditionally on resource != NULL, so this
may lead to a bogus free. Found by clang -Wsometimes-uninitialized.

7 years agoMerge pull request #2868 from stapelberg/mouse
Ingo Bürk [Sun, 20 Aug 2017 16:07:34 +0000 (18:07 +0200)]
Merge pull request #2868 from stapelberg/mouse

t/264-keypress-numlock: add mouse binding test

7 years agot/264-keypress-numlock: add mouse binding test 2868/head
Michael Stapelberg [Sun, 20 Aug 2017 16:00:10 +0000 (18:00 +0200)]
t/264-keypress-numlock: add mouse binding test

fixes #2523

7 years agoRespect dont_warp flag when moving containers (#2867)
Michael Stapelberg [Sun, 20 Aug 2017 15:07:23 +0000 (17:07 +0200)]
Respect dont_warp flag when moving containers (#2867)

fixes #2681
fixes #2592

7 years agoi3bar: only restart child when command changed (#2866)
Michael Stapelberg [Sun, 20 Aug 2017 13:30:27 +0000 (15:30 +0200)]
i3bar: only restart child when command changed (#2866)

this is a follow-up to
https://github.com/i3/i3/commit/98f202dd1b2782d11a713513f5dcca2f52daab73

fixes #2689

7 years agoFocus windows upon ConfigureWindow with stack-mode=Above (#2865)
Michael Stapelberg [Sun, 20 Aug 2017 12:56:44 +0000 (14:56 +0200)]
Focus windows upon ConfigureWindow with stack-mode=Above (#2865)

fixes #2708
fixes #2745

7 years agoMerge pull request #2864 from stapelberg/fixconfig
Michael Stapelberg [Sun, 20 Aug 2017 11:16:53 +0000 (13:16 +0200)]
Merge pull request #2864 from stapelberg/fixconfig

Improve error messages for incorrect config lines starting with “set”

7 years agot/201-config-parser: update expected token list 2864/head
Michael Stapelberg [Sun, 20 Aug 2017 11:12:06 +0000 (13:12 +0200)]
t/201-config-parser: update expected token list

7 years agoparser: only skip set[\s], not set.*
Michael Stapelberg [Sun, 20 Aug 2017 10:58:13 +0000 (12:58 +0200)]
parser: only skip set[\s], not set.*

fixes #2564

7 years agostart nagbar when encountering invalid set statements
Michael Stapelberg [Sun, 20 Aug 2017 10:57:26 +0000 (12:57 +0200)]
start nagbar when encountering invalid set statements

related to #2564

7 years agoSkip lines consisting only of “set”
Michael Stapelberg [Sun, 20 Aug 2017 10:57:04 +0000 (12:57 +0200)]
Skip lines consisting only of “set”

7 years ago(Re-)initialize optional fields to empty strings
Michael Stapelberg [Sun, 20 Aug 2017 10:55:55 +0000 (12:55 +0200)]
(Re-)initialize optional fields to empty strings

7 years agoBugfix: check bounds before accessing memory
Michael Stapelberg [Sun, 20 Aug 2017 10:54:49 +0000 (12:54 +0200)]
Bugfix: check bounds before accessing memory

This fixes the following issue when having an error early in the config file:

==1562==ERROR: AddressSanitizer: heap-buffer-overflow on address 0x6220000180ff at pc 0x55c837edb1d3 bp 0x7ffee7534650 sp 0x7ffee7534648
READ of size 1 at 0x6220000180ff thread T0
    #0 0x55c837edb1d2 in start_of_line ../../i3/src/config_parser.c:238
    #1 0x55c837edc96f in parse_config ../../i3/src/config_parser.c:493
    #2 0x55c837edf527 in parse_file ../../i3/src/config_parser.c:1091
    #3 0x55c837ecf14b in parse_configuration ../../i3/src/config.c:65
    #4 0x55c837ed1ef4 in load_configuration ../../i3/src/config.c:230
    #5 0x55c837f0a8d0 in main ../../i3/src/main.c:539
    #6 0x7fb63ae042b0 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x202b0)
    #7 0x55c837e95eb9 in _start (/home/michael/i3/build/i3+0x4beb9)

0x6220000180ff is located 1 bytes to the left of 5165-byte region [0x622000018100,0x62200001952d)
allocated by thread T0 here:
    #0 0x7fb63e590cf8 in malloc (/usr/lib/x86_64-linux-gnu/libasan.so.3+0xc1cf8)
    #1 0x55c837f59aa6 in smalloc ../../i3/libi3/safewrappers.c:24
    #2 0x55c837edef45 in parse_file ../../i3/src/config_parser.c:1029
    #3 0x55c837ecf14b in parse_configuration ../../i3/src/config.c:65
    #4 0x55c837ed1ef4 in load_configuration ../../i3/src/config.c:230
    #5 0x55c837f0a8d0 in main ../../i3/src/main.c:539
    #6 0x7fb63ae042b0 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x202b0)