모듈:Curry: 두 판 사이의 차이
둘러보기로 이동
검색으로 이동
>Hsl0 편집 요약 없음 |
>Hsl0 편집 요약 없음 |
||
3번째 줄: | 3번째 줄: | ||
return mw.getCurrentFrame():preprocess(mw.text.decode(mw.text.unstripNoWiki(source)):gsub("{{{%f[^{](.-)}}}", function(exp) | return mw.getCurrentFrame():preprocess(mw.text.decode(mw.text.unstripNoWiki(source)):gsub("{{{%f[^{](.-)}}}", function(exp) | ||
local group = mw.text.split(exp, "|") | local group = mw.text.split(exp, "|") | ||
return args and args[tonumber(group[1]) or group[1]] | return args and args[tonumber(group[1]) or group[1]] | ||
end)) | end)) | ||
end | end |
2023년 8월 26일 (토) 19:06 판
위키텍스트 코드 조각에서 nowiki를 해제하고 파라미터에서 사용할 변수를 주입합니다.
모듈:IIFE와 유사하지만 변수가 할당되지 않았을 때는 기본값으로 대체하지 않고 유보하여 원본 코드가 나오게 합니다. 그러면 이 코드를 밖의 IIFE에서 변수를 대체할 수 있게 됩니다. 이런 방식으로 미디어위키 상에서 함수형 프로그래밍에 필수적인 커링을 구현합니다.
사용법
{{#invoke:Curry|(위키텍스트 코드 또는 문서명)|...(위키텍스트 코드에서 사용할 변수)}}
함수 이름이 들어가는 자리에 위키텍스트 코드나 틀 이름 및 문서명을 넣고, 그 뒤에 변수를 할당하면 됩니다.
키 없이 변수를 작성하면 1, 2, 3...과 같은 숫자 키에 할당되고, 등호를 사용하여 변수 이름을 지정할 수도 있습니다.
위키텍스트 코드 내에서 변수를 불러오는 것은 틀의 파라미터를 불러오는 방법과 동일합니다. {{{(변수 이름)}}}
나 {{{(변수 이름)|(기본값)}}}
와 같이 작성하면 변수값이 그 자리에 들어옵니다.
이 모듈은 변수가 없어도 기본값을 적용하지 않기 때문에 제일 바깥쪽에 모듈:IIFE를 사용하여 최종 마무리를 해야합니다.
예시
code_blocks 코드
{{#invoke:IIFE|{{#invoke:Curry|<nowiki>{{{1|}}}, {{{2|}}}!</nowiki>|Hello}}|World}}
code
description 결과
Hello, !
위 설명은 모듈:Curry/설명문서의 내용을 가져와 보여주고 있습니다. (편집 | 역사) 이 모듈에 대한 수정 연습과 시험은 연습장 (만들기 | 미러)과 시험장 (만들기)에서 할 수 있습니다. 분류는 /설명문서에 넣어주세요. 이 모듈에 딸린 문서. |
function tfnew(source)
return function(args)
return mw.getCurrentFrame():preprocess(mw.text.decode(mw.text.unstripNoWiki(source)):gsub("{{{%f[^{](.-)}}}", function(exp)
local group = mw.text.split(exp, "|")
return args and args[tonumber(group[1]) or group[1]]
end))
end
end
return setmetatable({}, {
__index = function(tbl, source)
return function(frame)
local func = tfnew(source)
return func(frame.args)
end
end
})