Merge pull request #7125 from Bo98/make-regex
extend/string: match multiline make variables
This commit is contained in:
commit
42477a1aaa
@ -41,7 +41,7 @@ module StringInreplaceExtension
|
|||||||
# Looks for Makefile style variable definitions and replaces the
|
# Looks for Makefile style variable definitions and replaces the
|
||||||
# value with "new_value", or removes the definition entirely.
|
# value with "new_value", or removes the definition entirely.
|
||||||
def change_make_var!(flag, new_value)
|
def change_make_var!(flag, new_value)
|
||||||
return if gsub!(/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=[ \t]*(.*)$/, "#{flag}=#{new_value}", false)
|
return if gsub!(/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=[ \t]*((?:.*\\\n)*.*)$/, "#{flag}=#{new_value}", false)
|
||||||
|
|
||||||
errors << "expected to change #{flag.inspect} to #{new_value.inspect}"
|
errors << "expected to change #{flag.inspect} to #{new_value.inspect}"
|
||||||
end
|
end
|
||||||
@ -50,7 +50,7 @@ module StringInreplaceExtension
|
|||||||
def remove_make_var!(flags)
|
def remove_make_var!(flags)
|
||||||
Array(flags).each do |flag|
|
Array(flags).each do |flag|
|
||||||
# Also remove trailing \n, if present.
|
# Also remove trailing \n, if present.
|
||||||
unless gsub!(/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=.*$\n?/, "", false)
|
unless gsub!(/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=(?:.*\\\n)*.*$\n?/, "", false)
|
||||||
errors << "expected to remove #{flag.inspect}"
|
errors << "expected to remove #{flag.inspect}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -58,6 +58,6 @@ module StringInreplaceExtension
|
|||||||
|
|
||||||
# Finds the specified variable
|
# Finds the specified variable
|
||||||
def get_make_var(flag)
|
def get_make_var(flag)
|
||||||
self[/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=[ \t]*(.*)$/, 1]
|
self[/^#{Regexp.escape(flag)}[ \t]*[\\?\+\:\!]?=[ \t]*((?:.*\\\n)*.*)$/, 1]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -53,6 +53,24 @@ describe StringInreplaceExtension do
|
|||||||
EOS
|
EOS
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "with newlines" do
|
||||||
|
let(:string) do
|
||||||
|
<<~'EOS'
|
||||||
|
CFLAGS = -Wall -O2 \
|
||||||
|
-DSOME_VAR=1
|
||||||
|
LDFLAGS = -lcrypto -lssl
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is successfully replaced" do
|
||||||
|
subject.change_make_var! "CFLAGS", "-O3"
|
||||||
|
expect(subject).to eq <<~EOS
|
||||||
|
CFLAGS=-O3
|
||||||
|
LDFLAGS = -lcrypto -lssl
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "empty flag between other flags" do
|
context "empty flag between other flags" do
|
||||||
@ -146,6 +164,23 @@ describe StringInreplaceExtension do
|
|||||||
EOS
|
EOS
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "with newlines" do
|
||||||
|
let(:string) do
|
||||||
|
<<~'EOS'
|
||||||
|
CFLAGS = -Wall -O2 \
|
||||||
|
-DSOME_VAR=1
|
||||||
|
LDFLAGS = -lcrypto -lssl
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
|
it "is successfully removed" do
|
||||||
|
subject.remove_make_var! "CFLAGS"
|
||||||
|
expect(subject).to eq <<~EOS
|
||||||
|
LDFLAGS = -lcrypto -lssl
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context "multiple flags" do
|
context "multiple flags" do
|
||||||
@ -194,6 +229,20 @@ describe StringInreplaceExtension do
|
|||||||
expect(subject.get_make_var("CFLAGS")).to eq("-Wall -O2")
|
expect(subject.get_make_var("CFLAGS")).to eq("-Wall -O2")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "with newlines" do
|
||||||
|
let(:string) do
|
||||||
|
<<~'EOS'
|
||||||
|
CFLAGS = -Wall -O2 \
|
||||||
|
-DSOME_VAR=1
|
||||||
|
LDFLAGS = -lcrypto -lssl
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
|
||||||
|
it "extracts the value for a given variable" do
|
||||||
|
expect(subject.get_make_var("CFLAGS")).to match(/^-Wall -O2 \\\n +-DSOME_VAR=1$/)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe "#sub!" do
|
describe "#sub!" do
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user