スキップしてメイン コンテンツに移動

無理やり動かすっ!

去年の記事なんだけどそこのUserJavascriptが素敵過ぎたので、しばらくRTMはFirefoxで使っていたけどそれってある意味負けじゃねとか思ったので、無理やりOperaで動かせないかやってみた。

で、さっきやって見たら、二行だけコードいじったら使えた(笑)
くそ、俺はアホか!(アホです)

・リストのタブを左に動かす
・カウントをリストに加える
・Shift + j/k でリストをスイッチする

使えるのは多分上の三機能。残りの機能は使えなかった気がするけど、別に良いや(超無責任)

2/7追記
/*-- 追記ここから --*/
元ネタのURL張っていなかったので、張ります
http://userscripts.org/scripts/show/32518
/*-- 追記ここまで --*/


って事で、以下コード。
ライセンスは配布元に従います。
Opera10αで確認済。
これを使って生じたいかなるエラーやバグにはArcCosineは対応できません。
自己責任でお使いください。


// ==UserScript==
// @name A Bit Better RTM
// @namespace http://www.rememberthemilk.com
// @description Small improvements for Remember The Milk: display list tabs to the left; display tasks count; GoTo & MoveTo list quickly;
// @include http://www.rememberthemilk.com/*
// @include https://www.rememberthemilk.com/*
// ==/UserScript==
//

window.wrappedJSObject = window.wrappedJSObject || window;

function Autocomplete(inputField, box, autocompleteStore, callback)
{
this.inputField = inputField;
this.box = box;
this.autocompleteList = new AutocompleteList(inputField, autocompleteStore, this);
this.callback = callback;
this.hide();
this.bind();
}

Autocomplete.prototype.show = function()
{
this.box.wrappedJSObject.style.display = "block";
this.inputField && this.inputField.focus();
}

Autocomplete.prototype.hide = function()
{
this.box.wrappedJSObject.style.display = "none";
this.inputField && (this.inputField.value = "");
this.autocompleteList.clearOutput();
}

Autocomplete.prototype.doCallback = function()
{
var completion = this.autocompleteList.getCurrentCompletion();
this.hide();
this.callback(completion);
}

Autocomplete.prototype.bind = function()
{
var autocompleteList = this.autocompleteList;
var inputField = this.inputField;
var currentText = "";

var handleKeyPressEvent = function(event)
{
currentText = inputField.value;
if (event.keyCode == 9) // Tab
{
if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(event);
return false
}
else if (autocompleteList.isVisible)
{
if (event.keyCode == 13)// Enter
autocompleteList.parent.doCallback();
if (event.keyCode == 40)// Key down
autocompleteList.highlightNextCompletion();
else if (event.keyCode == 38) // Key up
autocompleteList.highlightPreviousCompletion();
else if (event.keyCode == 27) // Esc
autocompleteList.clearOutput();
}
else if (event.keyCode == 27)
autocompleteList.parent.hide();

return true;
};
var handleKeyUpEvent = function(event)
{
if (currentText === null || currentText != inputField.value)
autocompleteList.update();
};
var handleClickEvent = function(event)
{
if (autocompleteList.isVisible)
autocompleteList.hideOutput();

if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(event);
}

this.inputField.setAttribute("autocomplete", "off");
this.inputField.addEventListener("keypress", handleKeyPressEvent, false);
this.inputField.addEventListener("keyup", handleKeyUpEvent, false);
this.box.addEventListener("click", handleClickEvent, false);
this.autocompleteList.createOutput();
}

function AutocompleteList(inputField, autocompleteStore, parent)
{
this.inputField = inputField;
this.autocompleteStore = autocompleteStore;
this.parent = parent;
this.output = null;
this.completions = null;
this.position = -1;
this.isVisible = false;
}

AutocompleteList.prototype.createOutput = function()
{
if (!this.inputField) return;

this.output = document.createElement('div');
this.output.setAttribute('id','autoCompleteList_' + this.inputField.id);
this.output.style.border = "solid 1px black";
this.output.style.background = "white";
this.output.style.position = "absolute";
this.output.style.width = "150px";
this.output.style.visibility = "hidden";

this.inputField.parentNode.insertBefore(this.output, this.inputField.nextSibling);
}

AutocompleteList.prototype.showOutput = function()
{
this.output && (this.output.style.visibility = "visible");
this.isVisible = true;
}

AutocompleteList.prototype.hideOutput = function()
{
this.output && (this.output.style.visibility = "hidden");
this.isVisible = false;
}

AutocompleteList.prototype.clearOutput = function()
{
while(this.output && this.output.childNodes.length)
this.output.removeChild(this.output.firstChild);

this.position = -1;
this.hideOutput();
}

AutocompleteList.prototype.addCompletion = function(completion)
{
var autocompleteList = this;

var mouseOverHandler = function(event)
{
autocompleteList.position = this.position;
autocompleteList.highlightCompletion();
}

var mouseClickHandler = function(event)
{
autocompleteList.parent.doCallback();
}

var completionBox = document.createElement("div");
completionBox.style.textAlign = "left";
completionBox.style.paddingLeft = "2px";
completionBox.appendChild(document.createTextNode(completion));
completionBox.wrappedJSObject.position = this.output.childNodes.length;
completionBox.addEventListener("mouseover", mouseOverHandler, false);
completionBox.addEventListener("click", mouseClickHandler, false);
this.output.appendChild(completionBox);
}

AutocompleteList.prototype.highlightCompletion = function()
{
if (this.output && this.output.childNodes)
{
for (var i = 0; i < this.output.childNodes.length; ++i)
{
if (i == this.position)
{
this.output.childNodes[i].style.color = "white";
this.output.childNodes[i].style.background = "#316ac5";
}
else
{
this.output.childNodes[i].style.color = "black";
this.output.childNodes[i].style.background = "white";
}
}
}
}

AutocompleteList.prototype.highlightNextCompletion = function()
{
if (this.completions && this.completions.length > 0 && this.position < this.completions.length - 1)
{
++this.position;
this.highlightCompletion();
}
}

AutocompleteList.prototype.highlightPreviousCompletion = function()
{
if (this.completions && this.completions.length > 1 && this.position > 0)
{
--this.position;
this.highlightCompletion();
}
}

AutocompleteList.prototype.getCurrentCompletion = function()
{
if (this.completions && this.completions.length > 0)
return this.completions[this.position];

return null;
}

AutocompleteList.prototype.update = function()
{
if (this.inputField.value.length > 0)
{
this.completions = this.autocompleteStore.getCompletions(this.inputField.value);
if (this.completions && this.completions.length > 0)
{
this.clearOutput();
for (var i = 0; i < this.completions.length; ++i)
this.addCompletion(this.completions[i]);

this.showOutput();
this.highlightNextCompletion();
}
else
{
this.hideOutput();
this.position = -1;
}
}
else
{
this.hideOutput();
this.position = -1;
}
}

function ListAutocompleteStore()
{

}

ListAutocompleteStore.prototype.getCompletions = function(text)
{
if (window.wrappedJSObject.listTabs && window.wrappedJSObject.listTabs.entries && window.wrappedJSObject.listTabs.entries.length > 0)
{
var completions = new Array();

for (var i = 0; i < window.wrappedJSObject.listTabs.entries.length; ++i)
{
if (window.wrappedJSObject.listTabs.entries[i].toLowerCase().indexOf(text.toLowerCase()) == 0)
completions.push(window.wrappedJSObject.listTabs.entries[i]);
}

return completions;
}

return null;
}

window.wrappedJSObject.autocompletes = {};

var createAutoComplete = function(name, callback)
{
var autocompleteBox = document.createElement('div');

autocompleteBox.setAttribute("id", "autocompleteBox_" + name);
autocompleteBox.style.width = "240px";
autocompleteBox.style.position = "absolute";

autocompleteBox.innerHTML = '<div class="white_rbroundbox"> <div class="white_rbtop"> <div> <div></div> </div> </div> <div class="white_rbcontentwrap"> <div class="white_rbcontent"> <div class="taskcloudcontent" style="padding: 0px 5px 0px 5px; height: 17px;" id="listtabscontainer"><div style="width: 70px; font-weight: bold; float: left; height: 17px; padding-top: 1px;">' + name + '</div><div style="text-align: right; float: right; width: 155px; padding-right: 2px;"><input type="text" id="autocompleteInputField_' + name + '" name="text" style="width: 151px; ";/></div> </div> </div> </div> <div class="white_rbbot"> <div><div></div> </div> </div> </div> ';

document.body.appendChild(autocompleteBox);
var autocomplete = new Autocomplete(document.getElementById("autocompleteInputField_" + name),
document.getElementById("autocompleteBox_" + name),
new ListAutocompleteStore(),
callback);

function centerAutoCompleteBox()
{
var left = window.wrappedJSObject.innerWidth / 2 - 120 + window.wrappedJSObject.scrollX;
var top = window.wrappedJSObject.innerHeight / 2 - 10 + window.wrappedJSObject.scrollY;

autocompleteBox.style.left = left + "px";
autocompleteBox.style.top = top + "px";
}

centerAutoCompleteBox();
window.addEventListener("scroll", centerAutoCompleteBox, false);
window.addEventListener("resize", centerAutoCompleteBox, false);

return autocomplete;
}

var createAutoCompletes = function()
{
window.wrappedJSObject.autocompletes["goTo"] = createAutoComplete("GO TO: ", selectListByName);
window.wrappedJSObject.autocompletes["moveTo"] = createAutoComplete("MOVE TO: ", moveToListByName);
}

var moveToListByName = function(text)
{
if (!window.wrappedJSObject.listTabs || !window.wrappedJSObject.listTabs.entries)
return;

for (var i = 0; i < window.wrappedJSObject.listTabs.entries.length; ++i)
{
if (window.wrappedJSObject.listTabs.entries[i].toLowerCase() == text.toLowerCase())
window.wrappedJSObject.control.tasksSelectionChanged("", ["", "tasks.moveTo." + window.wrappedJSObject.listTabs.data[i][1]]);
}
}

var selectListByName = function(text)
{
if (!window.wrappedJSObject.listTabs || !window.wrappedJSObject.listTabs.entries)
return;

for (var i = 0; i < window.wrappedJSObject.listTabs.entries.length; ++i)
{
if (window.wrappedJSObject.listTabs.entries[i].toLowerCase() == text.toLowerCase())
window.wrappedJSObject.listTabs.selectTabByPosition(i);
}
}

var hideAutocompletes = function()
{
if (window.wrappedJSObject.autocompletes)
for (var name in window.wrappedJSObject.autocompletes)
window.wrappedJSObject.autocompletes[name].hide();
}

// end Autocomplete

var createLeftColumn = function()
{
var leftColumn = document.createElement('div');
var appView = document.getElementById("appview");
var listBox = document.getElementById("listbox");

leftColumn.setAttribute('id','leftColumn');
leftColumn.style.cssFloat = "left";
leftColumn.style.paddingLeft = "5px";
leftColumn.style.paddingRight = "8px";
leftColumn.style.display = "none";

if (appView && listBox)
appView.insertBefore(leftColumn, listBox);
}

var createListTabsContainer = function()
{
var listTabsBox = document.createElement('div');
var leftColumn = document.getElementById("leftColumn");

if (leftColumn)
{
listTabsBox.innerHTML = '<div class="white_rbroundbox"> <div class="white_rbtop"> <div> <div></div> </div> </div> <div class="white_rbcontentwrap"> <div class="white_rbcontent"> <table><tr><td><div class="taskcloudcontent" style="padding: 0px 5px 0px 5px;" id="listtabscontainer"> </div></td></tr></table> </div> </div> <div class="white_rbbot"> <div><div></div> </div> </div> </div> ';

leftColumn.appendChild(listTabsBox);
}
}

var moveListTabs = function()
{
var listTabs = document.getElementById("listtabs");
if (listTabs)
{
listTabs.className = "";
listTabs.style.width = "100%";

var listTabsContainer = document.getElementById("listtabscontainer");

if (listTabsContainer)
listTabsContainer.appendChild(listTabs);
}
}

var hideLeftColumn = function()
{
var content = document.getElementById("content");
var leftColumn = document.getElementById("leftColumn");

if (leftColumn)
{
leftColumn.style.display = "none";
content.style.width = "980px";
}
}

var showLeftColumn = function()
{
var content = document.getElementById("content");
var leftColumn = document.getElementById("leftColumn");
var listTabsContainer = document.getElementById("listtabscontainer");

if (leftColumn)
{
leftColumn.style.display = "block";
leftColumn.style.width = Math.round(listTabsContainer.clientWidth * 1.14) + "px";
content.style.width = (973 + leftColumn.clientWidth) + "px";
}
}

var moveTabsToTheLeft = function()
{
var content = document.getElementById("content");
var listBox = document.getElementById("listbox");
var tools_spacer = document.getElementById("tools_spacer");
var sorting = document.getElementById("sorting");
var tools = document.getElementById("tools");

createLeftColumn();
createListTabsContainer();
moveListTabs();

var leftColumn = document.getElementById("leftColumn");

var handleViewChanged = function(d, e)
{
if (e[0][1] == "Tasks")
hideLeftColumn();
else if (e[1][1] == "Tasks")
showLeftColumn();
}

if (window.wrappedJSObject.messageBus)
window.wrappedJSObject.messageBus.subscribe(handleViewChanged, window.wrappedJSObject.view.getUniqueMessageBusName() + "viewChanged");

if (tools_spacer)
{
tools_spacer.style.paddingTop = "1px";
tools_spacer.style.borderTop = "1px solid #CACACA";
}

if (sorting)
sorting.style.marginTop = "0px";

if (tools)
tools.style.paddingTop = "5px";

if (content && window.wrappedJSObject.view)
{
if (window.wrappedJSObject.view.getSelected() == "Tasks")
showLeftColumn();
else
hideLeftColumn();
}
}

var handleKeyPressEvent = function(ev, ignoreCombo)
{
ev || (ev = window.event);

if (ev == null)
return;

var target = null;

if (window.wrappedJSObject.utility)
target = window.wrappedJSObject.utility.getEventTarget(ev);

if (target == null)
return true

var pressed = (ev.charCode) ? ev.charCode: ((ev.which) ? ev.which: ev.keyCode);

if (target != null && target.type != null && (target.type == "textarea" || target.type == "input" || target.type.indexOf("select") == 0 || target.type == "button" || target.type === "submit" || target.type == "text" || target.type == "password" || (target.id != null && target.id == "map")))
return true

var tabs = null;

if (window.wrappedJSObject.view)
tabs = window.wrappedJSObject.view.getViewTabs();

if (tabs)
{
switch (pressed)
{
case 74:
if (ev.shiftKey)
{
tabs.selectRight();
if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(ev);

return false
}
break;
case 75:
if (ev.shiftKey)
{
tabs.selectLeft();
if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(ev);

return false
}
break;
case 103:
if (ev.ctrlKey)
{
hideAutocompletes();
window.wrappedJSObject.autocompletes["goTo"] && window.wrappedJSObject.autocompletes["goTo"].show();
if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(ev);

return false;
}
break;
case 109:
if (ev.ctrlKey)
{
hideAutocompletes();
window.wrappedJSObject.autocompletes["moveTo"] && window.wrappedJSObject.autocompletes["moveTo"].show();
if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(ev);

return false;
}
break
}
}

return true;
}

var overrideBodyKeyPressHandler = function()
{
if (window.wrappedJSObject.eventMgr)
{
var oldBodyKeyPressHandler = window.wrappedJSObject.eventMgr.bodyKeyPressHandler;

window.wrappedJSObject.eventMgr.bodyKeyPressHandler = function(ev, ignoreCombo)
{
if (handleKeyPressEvent(ev, ignoreCombo))
return oldBodyKeyPressHandler.call(window.wrappedJSObject.eventMgr, ev, ignoreCombo);

return true;
}
}
}

var overrideListTabsBlitDiv = function()
{
if (window.wrappedJSObject.listTabs)
{
var oldBlitDiv = window.wrappedJSObject.listTabs.blitDiv;

window.wrappedJSObject.listTabs.blitDiv = function()
{
oldBlitDiv.call(window.wrappedJSObject.listTabs);
refreshListTabsStyles();
showTasksCount();
hideLists();
}

window.wrappedJSObject.listTabs.blitDiv();
}
}

var refreshListTabsStyles = function()
{
var divListTabs = document.getElementById("listtabs");

if (divListTabs)
{
divListTabs.firstChild.style.listStyle = "none";
divListTabs.firstChild.style.padding = "0px 5px 0px 5px";
divListTabs.firstChild.style.whiteSpace = "nowrap";
}
}

var hideLists = function()
{
if (window.wrappedJSObject.listTabs)
{
var listItems = window.wrappedJSObject.listTabs.div.getElementsByTagName("li");

for (var i = 0; i < window.wrappedJSObject.listTabs.data.length; ++i)
{
if (window.wrappedJSObject.listTabs.data[i] && isListHidden(window.wrappedJSObject.listTabs.data[i][1]))
listItems[i].style.display = "none";
}

/*if (window.wrappedJSObject.view.getSelected() == "Tasks")
showLeftColumn();*/
}
}

var overrideListTabsSelectLeft = function()
{
if (window.wrappedJSObject.listTabs)
{
var oldListTabsSelectLeft = window.wrappedJSObject.listTabs.selectLeft;

window.wrappedJSObject.listTabs.selectLeft = function()
{
var position = this.selected - 1;

while (true)
{
if (position >= 0)
{
if (!isListHidden(this.data[position][1]))
break;

--position;
}
else
position = this.entries.length - 1;
}

this.selectTabByPosition(position);
}
}
}

var overrideListTabsSelectRight = function()
{
if (window.wrappedJSObject.listTabs)
{
var oldListTabsSelectRight = window.wrappedJSObject.listTabs.selectRight;

window.wrappedJSObject.listTabs.selectRight = function()
{
var position = this.selected + 1;

while (true)
{
if (position < this.entries.length)
{
if (!isListHidden(this.data[position][1]))
break;

++position;
}
else
position = 0;
}

this.selectTabByPosition(position);
}
}
}

var showTasksCount = function()
{
if (window.wrappedJSObject.listTabs)
{
var listItems = window.wrappedJSObject.listTabs.div.getElementsByTagName("li");

for (var i = 0; window.wrappedJSObject.listTabs.data && window.wrappedJSObject.listTabs.data[i]; ++i)
{
var tasksCount = 0;

if (window.wrappedJSObject.listTabs.data[i][2])
{
var filter = window.wrappedJSObject.listTabs.data[i][2];

if (filter && filter.indexOf("status:") < 0)
filter = "(" + filter + ") and (status:incomplete)";

if (window.wrappedJSObject.overviewList && filter)
tasksCount = window.wrappedJSObject.overviewList.getFilteredList(filter).length
}
else
{
if (window.wrappedJSObject.format)
tasksCount = window.wrappedJSObject.format.getListStatistics(window.wrappedJSObject.listTabs.data[i][1])[5];

listItems[i].firstChild.style.color = "black";
}

if (tasksCount > 0)
listItems[i].firstChild.innerHTML = listItems[i].firstChild.innerHTML + " (" + tasksCount + ")";
}
}
}

var subscribeToFilterEditFinished = function()
{
if (window.wrappedJSObject.messageBus)
window.wrappedJSObject.messageBus.subscribe(window.wrappedJSObject.listTabs.blitDiv, window.wrappedJSObject.listList.mbn + "setFilterSuccess");
}

var overrideTaskCloudUpdate = function()
{
if (window.wrappedJSObject.taskCloud)
{
var oldTaskCloudUpdate = window.wrappedJSObject.taskCloud.update;

window.wrappedJSObject.taskCloud.update = function()
{
oldTaskCloudUpdate.call(window.wrappedJSObject.taskCloud);

if (window.wrappedJSObject.listTabs)
window.wrappedJSObject.listTabs.blitDiv();
}
}
}

//var hiddenLists = GM_getValue("hiddenLists", "");
var hiddenLists = "";

var isListHidden = function(listID)
{
if (hiddenLists)
return hiddenLists.indexOf(listID) >= 0;

return false;
}

var isListArchived = function(listID)
{
if (window.wrappedJSObject.stateMgr.lists[listID] && window.wrappedJSObject.stateMgr.lists[listID].archived)
return true;

return false;
}

var hideList = function(entry)
{
hiddenLists = (hiddenLists || "") + entry[0] + ",";

GM_setValue("hiddenLists", hiddenLists);

window.wrappedJSObject.listList.list.updateEntry(entry);
window.wrappedJSObject.listTabs.blitDiv();
}

var showList = function(entry)
{
hiddenLists = hiddenLists.replace(entry[0], "");
hiddenLists = hiddenLists.replace(",,", ",");

GM_setValue("hiddenLists", hiddenLists);

window.wrappedJSObject.listList.list.updateEntry(entry);
window.wrappedJSObject.listTabs.blitDiv();
}


var overrideListListUpdateEntry = function()
{
if (window.wrappedJSObject.listList)
{
var oldListListUpdateEntry = window.wrappedJSObject.listList.list.updateEntry;

window.wrappedJSObject.listList.list.updateEntry = function(entry, D)
{
oldListListUpdateEntry.call(window.wrappedJSObject.listList.list, entry, D);

var index = window.wrappedJSObject.listList.list.map[entry[0]];
var row = window.wrappedJSObject.listList.list.table.rows[index];

row.entry = entry;
row.rowText.innerHTML = "<div id='listName_" + entry[0] + "' style='float: left;'>" + entry[1] + "</div><div style='align: right; float: right;'><a href=\"# \" id='displayListLink_" + entry[0] + "'></a></div>";

var displayListLink = document.getElementById('displayListLink_' + entry[0]);
var listName = document.getElementById('listName_' + entry[0]);

var listClickHandler = function(event)
{
if (isListHidden(entry[0]))
showList(entry);
else
hideList(entry);


if (window.wrappedJSObject.utility)
window.wrappedJSObject.utility.stopEvent(event);
}

displayListLink.addEventListener('click', listClickHandler, false);

if (!isListArchived(entry[0]))
{
if (isListHidden(entry[0]))
{
displayListLink.innerHTML = "show";
listName.style.color = "#cacaca";
}
else
{
displayListLink.innerHTML = "hide";
listName.style.color = "";
}
}
}

window.wrappedJSObject.listList.doStyles();
}
}

window.addEventListener('load', overrideListTabsBlitDiv, false);
window.addEventListener('load', moveTabsToTheLeft, false);
window.addEventListener('load', overrideBodyKeyPressHandler, false);
window.addEventListener('load', overrideTaskCloudUpdate, false);
window.addEventListener('load', overrideListTabsSelectLeft, false);
window.addEventListener('load', overrideListTabsSelectRight, false);
window.addEventListener('load', subscribeToFilterEditFinished, false);
window.addEventListener('load', createAutoCompletes, false);
window.addEventListener('click', hideAutocompletes, false);

window.addEventListener('load', overrideListListUpdateEntry, false);

コメント

このブログの人気の投稿

EFIブートローダを移動した話

EFIブートローダを移動した HX90に環境を整え終わってから、アホな事をしたので、その記録を残す。 SSD: Cドライブ SSD: Dドライブ(データストレージ用) + ESP※ SSD: Eドライブ(データストレージ用) ※ESP(EFI System Partition) インストールした時、こんな構成だった。 ESPがDドライブにあるのが気持ち悪かったので、これを削除した。 そしたら、BIOS画面が出るだけになり、Windowsが起動しなくなった。 移動手順 この時の自分はMBRをふっ飛ばした時と同じ現象だと思ったので、MBRというキーワードで検索したが、今はEFIブートローダーと呼んでいるらしい。 【Win10】任意のディスクにEFIブートローダをインストールする 色々検索した結果この記事が参考になった。 Diskpartを使って、パーティションを新たに分割し、bcdbootを実行して、無事に事なきを得た。 パーティションの分割はこんな感じ Diskpart Select volume 0 shrink desired = 200 Select disk 0 Create partition EFI size=200 Format quick fs=fat32 label="ESP" Assign letter=P exit EFIブートローダーのインストールはこんな感じ bcdboot C:\Windows /s P: /f UEFI ちなみに、自分の環境だけの問題なのだが、コマンドラインで、「\」を入力するのができなかった。我が家のキーボードはHHKBだけなので、日本語配列を無理やり適用されると、バックスラッシュが入力できないという不具合が生じる。 結局、コマンドプロンプトからマウスで範囲選択してコピーして貼り付けるという荒業でクリアした。 普通の人は、何も考えずに、\を入力すれば良い。 最終的に SSD: Cドライブ + ESP※ SSD: Dドライブ(データストレージ用) SSD: Eドライブ(データストレージ用) ※ESP(EFI System Partition) という構成に切り替えることができた。

Windows版gVimをアンインストールした日

Windows 版 gVim をアンインストールした話 以前に、 Windows11 on WSL2 + wezterm + Neovim = 最強開発環境 という痛々しい記事を書いたのだが、その続きの記事と言っても過言ではない。 この記事は Vim 駅伝 の 3 月 1 日の記事である。 前回はぺりーさんの netrw を使うために という記事だった。 次回は kuuote さんの Vim 側の組み込みプラグインを無効化するハック という記事である。 gVim との付き合い 思い返してみると、gVim との付き合いは大分長くなった。エディタとしては 自分の人生の中で最も長く付き合ってきたエディタ と言える。Vim のインターフェースとして gVim を何度も使ってきた。自分の手持ちのマシンは Windows なので、必然的に gVim を選択肢として選ぶ必要があった。 gVim の良さは何か。それは、Windows とのシームレスな関係であり、Windows OS の機能をそのまま使いたい場合に有用である。かつての自分にとってこの部分は非常に重要であった。具体的には、印刷機能と画面半透明化機能であり、これが無いとやってられないという認識であった。 しかし、時代が進み、自分の技術力の向上や考え方の変化、さらに Vim 周りのプラグインの更新が進むと gVim で運用していく事がだんだんと億劫になっていったというのが事実である。故に、 WSL2 上で動く Neovim の快適さに心が打ち震えた のである。 技術力の向上に伴う考え方の変化 かつての自分は 何でも gVim で処理したいな と考えていた。メールを見たり天気を見たり、Twitter を見たりするのに、gVim を活用していた。かつての Emacs 使いの guru のような立ち位置を目指していたというのがある。2000 年代初頭にインターネットに多少なりとも触れていた人ならば、「それ Pla」という古の単語を思い浮かべるかもしれない。この概念を持ち出すのはあまりにも古すぎるが、結局言いたいのは、 1 つの手法で全部をこなす という考え方だ。ネットを見るのにわざわざブラウザに切り替えるのはもったいないという今となっては情熱に似た何かを当時は多くの人が持っていた。 しかし、自分自身の技術力...

Let's note CF-SZ6にGoogle Play入りChromeOSを入れて、超軽量Chromebookを手に入れた

Let's note CF-SZ6にGoogle Play入りChromeOSをインストールする 先日、 魔が差して 、 Let's note CF-SZ6の中古 をポチってしまった。なんとなく ChromeOS に触りたくなり、中古のやっすいPCに入れたらええんちゃうんという心の声に逆らえなくなった。 で、一旦ChromeOS Flexを入れて使ってみたんだけれど、やっぱりGoogle Playのアプリが入れられないのはNG。 自分が欲しかったのは、Google Playが使えるChromeOSなんやという事で、 ネットのインストール記事 を探して、入れることにした。 ほぼ、そこの記事通りにインストールしているが、自分なりのアレンジも加えているので、参考にする人は参考にしていただきたい。 手順は下記の通り 軽量Linuxをダウンロードする 対応しているChromeOSのバージョンを調べ、ダウンロードする Brunchをダウンロードする Rufusをダウンロードする USBメモリーに軽量Linuxをインストールし、ChromeOSをコピペする USBメモリーから、実際に軽量Linuxを起動して、インストールコマンドを実行する 軽量Linuxをダウンロードする インストール作業用として、軽量LinuxをUSBメモリーに構築する。 Linux Mint がオススメという事なので、こいつをダウンロードする。 ダウンロードページ にアクセスし、Xfce Editionをダウンロード。 ダウンロードが完了すると、 linuxmint-21.3-xfce-64bit.iso みたいなファイルが出来上がっている。 対応しているChromeOSのバージョンを調べ、ダウンロードする 自分が購入した Let's note CF-SZ6 は、Core i5-7200Uとの事なので、7世代目のCPUとなる。 この7世代目のCPUに対応しているのは、board: rammusのバージョンになる。 https://cros.tech/ にアクセスし、 rammus を検索すると、対応するChrome OSのバージョンが出てくるので、これをダウンロードする。 自分は、 stable バージョンの 126 をダウンロードした。 ダウン...