c4se記:さっちゃんですよ☆

.。oO(さっちゃんですよヾ(〃l _ l)ノ゙☆)

.。oO(此のblogは、主に音樂考察Programming に分類されますよ。ヾ(〃l _ l)ノ゙♬♪♡)

音樂は SoundCloud に公開中です。

考察は現在は主に Scrapbox で公表中です。

Programming は GitHub で開發中です。

ローマ字→ひらがな変換関数を三年ぶりに改善した

JavaScriptね。三年前に
ローマ字→平仮名の表 #javascript - c4se記:さっちゃんですよ☆ http://c4se.hatenablog.com/entry/20100210/1265741074
ローマ字→平仮名変換関数 #javascript - c4se記:さっちゃんですよ☆ http://c4se.hatenablog.com/entry/20100330/1269906760
を書いたが、あんまりなcodeなのに、未だに需要があるようなので、改善した。
変換tableはGoogle日本語入力のdefault設定から抜き出した。これを抜き出せる事は、三年前に上記codeを書いた、直後に気が附いていた。

// License: Public Domain <utakata.c4se@gmail.com>
(function(scope) {
scope.roman2hiragana = roman2hiragana;

/**
 * @param {String} roman
 * @return {String}
 */
function roman2hiragana(roman) {
  return r2h_recur(roman, '');
  // var match,
  //     i = 0, iz = 0, hiragana = '';

  // for (i = 0, iz = roman.length; i < iz;) {
  //   match = roman.slice(i).match(regex);
  //   if (match) {
  //     hiragana += table[match[0]].split('\t')[0];
  //     i += match[0].length;
  //     if (table[match[0]].indexOf('\t') !== -1) {
  //       roman = roman.slice(0, i) + table[match[0]].split('\t')[1] + roman.slice(i);
  //       iz = roman.length;
  //     }
  //   } else {
  //     hiragana += roman[i];
  //     ++i;
  //   }
  // }
  // return hiragana;
}

/**
 * @param {String} roman
 * @param {String} acum hiragana
 * @return {String}
 */
function r2h_recur(roman, acum) {
  var match, target;

  if (roman.length === 0) return acum;
  match = roman.match(regex);
  if (match) {
    target = table[match[0]].split('\t');
    return r2h_recur((target[1] || '') + roman.slice(match[0].length), acum + target[0]);
  } else {
    return r2h_recur(roman.slice(1), acum + roman[0]);
  }
}

/** @type {String} */
var table_str = "-	ー\n~	〜\n.	。\n,	、\nz/	・\nz.	…\nz,	‥\nzh	←\nzj	↓\nzk	↑\nzl	→\nz-	〜\nz[	『\nz]	』\n[	「\n]	」\nva	ゔぁ\nvi	ゔぃ\nvu	ゔ\nve	ゔぇ\nvo	ゔぉ\nvya	ゔゃ\nvyi	ゔぃ\nvyu	ゔゅ\nvye	ゔぇ\nvyo	ゔょ\nqq	っ	q\nvv	っ	v\nll	っ	l\nxx	っ	x\nkk	っ	k\ngg	っ	g\nss	っ	s\nzz	っ	z\njj	っ	j\ntt	っ	t\ndd	っ	d\nhh	っ	h\nff	っ	f\nbb	っ	b\npp	っ	p\nmm	っ	m\nyy	っ	y\nrr	っ	r\nww	っ	w\nwww	w	ww\ncc	っ	c\nkya	きゃ\nkyi	きぃ\nkyu	きゅ\nkye	きぇ\nkyo	きょ\ngya	ぎゃ\ngyi	ぎぃ\ngyu	ぎゅ\ngye	ぎぇ\ngyo	ぎょ\nsya	しゃ\nsyi	しぃ\nsyu	しゅ\nsye	しぇ\nsyo	しょ\nsha	しゃ\nshi	し\nshu	しゅ\nshe	しぇ\nsho	しょ\nzya	じゃ\nzyi	じぃ\nzyu	じゅ\nzye	じぇ\nzyo	じょ\ntya	ちゃ\ntyi	ちぃ\ntyu	ちゅ\ntye	ちぇ\ntyo	ちょ\ncha	ちゃ\nchi	ち\nchu	ちゅ\nche	ちぇ\ncho	ちょ\ncya	ちゃ\ncyi	ちぃ\ncyu	ちゅ\ncye	ちぇ\ncyo	ちょ\ndya	ぢゃ\ndyi	ぢぃ\ndyu	ぢゅ\ndye	ぢぇ\ndyo	ぢょ\ntsa	つぁ\ntsi	つぃ\ntse	つぇ\ntso	つぉ\ntha	てゃ\nthi	てぃ\nt'i	てぃ\nthu	てゅ\nthe	てぇ\ntho	てょ\nt'yu	てゅ\ndha	でゃ\ndhi	でぃ\nd'i	でぃ\ndhu	でゅ\ndhe	でぇ\ndho	でょ\nd'yu	でゅ\ntwa	とぁ\ntwi	とぃ\ntwu	とぅ\ntwe	とぇ\ntwo	とぉ\nt'u	とぅ\ndwa	どぁ\ndwi	どぃ\ndwu	どぅ\ndwe	どぇ\ndwo	どぉ\nd'u	どぅ\nnya	にゃ\nnyi	にぃ\nnyu	にゅ\nnye	にぇ\nnyo	にょ\nhya	ひゃ\nhyi	ひぃ\nhyu	ひゅ\nhye	ひぇ\nhyo	ひょ\nbya	びゃ\nbyi	びぃ\nbyu	びゅ\nbye	びぇ\nbyo	びょ\npya	ぴゃ\npyi	ぴぃ\npyu	ぴゅ\npye	ぴぇ\npyo	ぴょ\nfa	ふぁ\nfi	ふぃ\nfu	ふ\nfe	ふぇ\nfo	ふぉ\nfya	ふゃ\nfyu	ふゅ\nfyo	ふょ\nhwa	ふぁ\nhwi	ふぃ\nhwe	ふぇ\nhwo	ふぉ\nhwyu	ふゅ\nmya	みゃ\nmyi	みぃ\nmyu	みゅ\nmye	みぇ\nmyo	みょ\nrya	りゃ\nryi	りぃ\nryu	りゅ\nrye	りぇ\nryo	りょ\nn'	ん\nnn	ん\nxn	ん\na	あ\ni	い\nu	う\nwu	う\ne	え\no	お\nxa	ぁ\nxi	ぃ\nxu	ぅ\nxe	ぇ\nxo	ぉ\nla	ぁ\nli	ぃ\nlu	ぅ\nle	ぇ\nlo	ぉ\nlyi	ぃ\nxyi	ぃ\nlye	ぇ\nxye	ぇ\nye	いぇ\nka	か\nki	き\nku	く\nke	け\nko	こ\nxka	ヵ\nxke	ヶ\nlka	ヵ\nlke	ヶ\nga	が\ngi	ぎ\ngu	ぐ\nge	げ\ngo	ご\nsa	さ\nsi	し\nsu	す\nse	せ\nso	そ\nca	か\nci	し\ncu	く\nce	せ\nco	こ\nqa	くぁ\nqi	くぃ\nqu	く\nqe	くぇ\nqo	くぉ\nkwa	くぁ\nkwi	くぃ\nkwe	くぇ\nkwo	くぉ\ngwa	ぐぁ\nza	ざ\nzi	じ\nzu	ず\nze	ぜ\nzo	ぞ\nja	じゃ\nji	じ\nju	じゅ\nje	じぇ\njo	じょ\njya	じゃ\njyi	じぃ\njyu	じゅ\njye	じぇ\njyo	じょ\nta	た\nti	ち\ntu	つ\ntsu	つ\nte	て\nto	と\nda	だ\ndi	ぢ\ndu	づ\nde	で\ndo	ど\nxtu	っ\nxtsu	っ\nltu	っ\nltsu	っ\nna	な\nni	に\nnu	ぬ\nne	ね\nno	の\nha	は\nhi	ひ\nhu	ふ\nfu	ふ\nhe	へ\nho	ほ\nba	ば\nbi	び\nbu	ぶ\nbe	べ\nbo	ぼ\npa	ぱ\npi	ぴ\npu	ぷ\npe	ぺ\npo	ぽ\nma	ま\nmi	み\nmu	む\nme	め\nmo	も\nxya	ゃ\nlya	ゃ\nya	や\nwyi	ゐ\nxyu	ゅ\nlyu	ゅ\nyu	ゆ\nwye	ゑ\nxyo	ょ\nlyo	ょ\nyo	よ\nra	ら\nri	り\nru	る\nre	れ\nro	ろ\nxwa	ゎ\nlwa	ゎ\nwa	わ\nwi	うぃ\nwe	うぇ\nwo	を\nwha	うぁ\nwhi	うぃ\nwhu	う\nwhe	うぇ\nwho	うぉ\nn	ん";

/** @type {Object.<String,String>} */
var table = (function() {
  var table = {};

  table_str.split('\n').forEach(function(row) {
    table[row.match(/^[^\t]+/)] = row.match(/^[^\t]+\t(.+)$/)[1];
  });
  return table;
}());

/** @type {RegExp} */
 var regex = (function() {
  var key, regexs = [];

  for (key in table) if (table.hasOwnProperty(key)) {
    regexs.push('(?:' + key.replace(/[~(?:)|.*+\[\]]/g, function(s) { return '\\' + s; }) + ')');
  }
  return new RegExp('^(?:' + regexs.join('|') + ')', 'i');
}());

}(this));
// vim:set tw=0 et sw=2 sts=2:
<meta charset="utf-8" />
<style>
  #roman { width: 40em; }
</style>
<input id="roman" type="text" placeholder="roman" />
<p id="hiragana">hiragana</p>
<script src="roman2hiragana.js"></script>
<script>
  var input = document.getElementById('roman');
  input.onkeyup = function() {
    var hiragana = roman2hiragana(roman.value);
    document.getElementById('hiragana').innerHTML = hiragana || 'hiragana';
  };
</script>


気が向いたらJavaも書くよ。たぶん書かないけど。
cf. 構築の館 :: トピックを表示 - ローマ字かな変換 http://bb2.atbb.jp/sliver/viewtopic.php?t=938 需要があるらしい。