我喜欢Aptana的片段。我想创建一个片段,创建一个String类型的私有类变量。我让它像这样工作:
# code from php bunle in Aptana 'snippets.rb'
# private member with getter setter and type checking for STRING
snippet 'private String MEMBER' do |s|
s.trigger = 'myps'
s.expansion = '
private \$${variableName}; /* string */
function set_${variableName}(/* string */ \$${variableName}) {
if(!is_string(\$${variableName})) {
throw new \Exception(get_class(\$this)."->set_${variableName}(): Parameter must be string!");
}
\$this->${variableName} = \$${variableName};
}
function get_${variableName}() {
return \$this->${variableName};
}
'
不幸的是我不知道Ruby,我想知道是否有可能得到像这样的getter / setter函数名(CamelCase):
private $member;
function setMember($member);
function getMember();
而不是:
private $member;
function set_member($member);
function get_member();
我必须在我公司使用Camel案例,我真的很想让它发挥作用。
谢谢你的帮助。
端
答案 0 :(得分:0)
我为我的问题找到了一个有效的解决方案。 我设法在Aptana Studio 3中以方便的方式生成getter和setter方法。 我没有通过片段实现这个解决方案,而是作为php'ruble'包中的命令。 我将发布此命令的源代码,即使我认为它是非常难看的代码,但我真的不知道ruby并且设法让它以某种方式工作。非常欢迎美化和更好的风格。
我发现此链接很有趣:https://wiki.appcelerator.org/display/tis/Ruble+Specification
如何获得命令:
require 'ruble'
command "getter_setter" do |cmd|
cmd.key_binding = "CONTROL+G"
cmd.input = :selection
cmd.output = :insert_as_text
cmd.invoke do |context|
input = STDIN.read
splittedInput = input.split(";")
type = nil
if splittedInput[1] != nil
type = splittedInput[1].gsub(/\s+/, "")
type = type.sub("//", "")
end
varName = splittedInput.first
varName = varName.sub("private", "")
varName = varName.gsub(/\s+/, "")
varName = varName.sub("$", "")
capitalizedName = varName.slice(0,1).capitalize + varName.slice(1..-1)
templateTypeless = "
function set#{capitalizedName}($#{varName}) {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->set#{capitalizedName}()');}
$this->#{varName} = $#{varName};
}
function get#{capitalizedName}() {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->get#{capitalizedName}()');}
return $this->#{varName};
}
"
templateBasicType = "
function set#{capitalizedName}(/* #{type} */ $#{varName}) {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->set#{capitalizedName}()');}
if(!is_#{type}(#{varName})) {
throw new \Exception(get_class($this).'->set#{capitalizedName}(): Parameter must be #{type}!');
}
$this->#{varName} = $#{varName};
}
function get#{capitalizedName}() {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->get#{capitalizedName}()');}
return $this->#{varName};
}
"
templateComplexType = "
function set#{capitalizedName}(#{type} $#{varName}) {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->set#{capitalizedName}()');}
$this->#{varName} = $#{varName};
}
function get#{capitalizedName}() {
global $MY_CLIENT_LOGGER;
if($MY_CLIENT_LOGGER) { $MY_CLIENT_LOGGER->log(get_class($this).'->get#{capitalizedName}()');}
return $this->#{varName};
}
"
outputString = ""
if type == nil
outputString = templateTypeless
elsif type == "string" or type == "int" or type == "float" or type == "double" or type == "array" or type == "object"
outputString = templateBasicType
else
outputString = templateComplexType
end
context.output = outputString
end
end
用法:
提示:
如果在私有成员声明行中添加注释,请注意基本类型(string / int / float / double / array / bool / object),然后您可以在setter中进行类型检查。
例如:private $var //string
提示:
如果将注释附加到私有成员声明行注释复杂类型,则可以在setter中进行类型检查。
例如:private $var //my\namespace\CComplexTypeClass