Add palindrome_addon and PalindromeTest.wgt 64/151664/1
authorjaekuk, lee <juku1999@samsung.com>
Thu, 21 Sep 2017 11:04:01 +0000 (20:04 +0900)
committerjaekuk, lee <juku1999@samsung.com>
Thu, 21 Sep 2017 11:04:01 +0000 (20:04 +0900)
Change-Id: I2d8abbe3295e7b7fe9aa8469d3179ba63d5ae591
Signed-off-by: jaekuk, lee <juku1999@samsung.com>
14 files changed:
wrt/wrt_support/extensions_repo/palindrome_addon/binding.gyp [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Makefile [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome.node.d [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome/palindrome.o.d [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/palindrome.node.d [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome.node [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome/palindrome.o [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/palindrome.node [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/binding.Makefile [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/config.gypi [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/build/palindrome.target.mk [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/package.json [new file with mode: 0755]
wrt/wrt_support/extensions_repo/palindrome_addon/palindrome.cc [new file with mode: 0755]
wrt/wrt_support/sample/wgt/PalindromeTest.wgt [new file with mode: 0755]

diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/binding.gyp b/wrt/wrt_support/extensions_repo/palindrome_addon/binding.gyp
new file mode 100755 (executable)
index 0000000..9d1ff12
--- /dev/null
@@ -0,0 +1,11 @@
+{
+  "targets": [
+    {
+      "target_name": "palindrome",
+      "sources": [ "palindrome.cc" ],
+      "include_dirs": [
+        "<!(node -e \"require('nan')\")"
+      ]
+    }
+  ]
+}
\ No newline at end of file
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Makefile b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Makefile
new file mode 100755 (executable)
index 0000000..3b658d5
--- /dev/null
@@ -0,0 +1,324 @@
+# We borrow heavily from the kernel build setup, though we are simpler since
+# we don't have Kconfig tweaking settings on us.
+
+# The implicit make rules have it looking for RCS files, among other things.
+# We instead explicitly write all the rules we care about.
+# It's even quicker (saves ~200ms) to pass -r on the command line.
+MAKEFLAGS=-r
+
+# The source directory tree.
+srcdir := ..
+abs_srcdir := $(abspath $(srcdir))
+
+# The name of the builddir.
+builddir_name ?= .
+
+# The V=1 flag on command line makes us verbosely print command lines.
+ifdef V
+  quiet=
+else
+  quiet=quiet_
+endif
+
+# Specify BUILDTYPE=Release on the command line for a release build.
+BUILDTYPE ?= Release
+
+# Directory all our build output goes into.
+# Note that this must be two directories beneath src/ for unit tests to pass,
+# as they reach into the src/ directory for data with relative paths.
+builddir ?= $(builddir_name)/$(BUILDTYPE)
+abs_builddir := $(abspath $(builddir))
+depsdir := $(builddir)/.deps
+
+# Object output directory.
+obj := $(builddir)/obj
+abs_obj := $(abspath $(obj))
+
+# We build up a list of every single one of the targets so we can slurp in the
+# generated dependency rule Makefiles in one pass.
+all_deps :=
+
+
+
+CC.target ?= $(CC)
+CFLAGS.target ?= $(CPPFLAGS) $(CFLAGS)
+CXX.target ?= $(CXX)
+CXXFLAGS.target ?= $(CPPFLAGS) $(CXXFLAGS)
+LINK.target ?= $(LINK)
+LDFLAGS.target ?= $(LDFLAGS)
+AR.target ?= $(AR)
+
+# C++ apps need to be linked with g++.
+LINK ?= $(CXX.target)
+
+# TODO(evan): move all cross-compilation logic to gyp-time so we don't need
+# to replicate this environment fallback in make as well.
+CC.host ?= gcc
+CFLAGS.host ?= $(CPPFLAGS_host) $(CFLAGS_host)
+CXX.host ?= g++
+CXXFLAGS.host ?= $(CPPFLAGS_host) $(CXXFLAGS_host)
+LINK.host ?= $(CXX.host)
+LDFLAGS.host ?=
+AR.host ?= ar
+
+# Define a dir function that can handle spaces.
+# http://www.gnu.org/software/make/manual/make.html#Syntax-of-Functions
+# "leading spaces cannot appear in the text of the first argument as written.
+# These characters can be put into the argument value by variable substitution."
+empty :=
+space := $(empty) $(empty)
+
+# http://stackoverflow.com/questions/1189781/using-make-dir-or-notdir-on-a-path-with-spaces
+replace_spaces = $(subst $(space),?,$1)
+unreplace_spaces = $(subst ?,$(space),$1)
+dirx = $(call unreplace_spaces,$(dir $(call replace_spaces,$1)))
+
+# Flags to make gcc output dependency info.  Note that you need to be
+# careful here to use the flags that ccache and distcc can understand.
+# We write to a dep file on the side first and then rename at the end
+# so we can't end up with a broken dep file.
+depfile = $(depsdir)/$(call replace_spaces,$@).d
+DEPFLAGS = -MMD -MF $(depfile).raw
+
+# We have to fixup the deps output in a few ways.
+# (1) the file output should mention the proper .o file.
+# ccache or distcc lose the path to the target, so we convert a rule of
+# the form:
+#   foobar.o: DEP1 DEP2
+# into
+#   path/to/foobar.o: DEP1 DEP2
+# (2) we want missing files not to cause us to fail to build.
+# We want to rewrite
+#   foobar.o: DEP1 DEP2 \
+#               DEP3
+# to
+#   DEP1:
+#   DEP2:
+#   DEP3:
+# so if the files are missing, they're just considered phony rules.
+# We have to do some pretty insane escaping to get those backslashes
+# and dollar signs past make, the shell, and sed at the same time.
+# Doesn't work with spaces, but that's fine: .d files have spaces in
+# their names replaced with other characters.
+define fixup_dep
+# The depfile may not exist if the input file didn't have any #includes.
+touch $(depfile).raw
+# Fixup path as in (1).
+sed -e "s|^$(notdir $@)|$@|" $(depfile).raw >> $(depfile)
+# Add extra rules as in (2).
+# We remove slashes and replace spaces with new lines;
+# remove blank lines;
+# delete the first line and append a colon to the remaining lines.
+sed -e 's|\\||' -e 'y| |\n|' $(depfile).raw |\
+  grep -v '^$$'                             |\
+  sed -e 1d -e 's|$$|:|'                     \
+    >> $(depfile)
+rm $(depfile).raw
+endef
+
+# Command definitions:
+# - cmd_foo is the actual command to run;
+# - quiet_cmd_foo is the brief-output summary of the command.
+
+quiet_cmd_cc = CC($(TOOLSET)) $@
+cmd_cc = $(CC.$(TOOLSET)) $(GYP_CFLAGS) $(DEPFLAGS) $(CFLAGS.$(TOOLSET)) -c -o $@ $<
+
+quiet_cmd_cxx = CXX($(TOOLSET)) $@
+cmd_cxx = $(CXX.$(TOOLSET)) $(GYP_CXXFLAGS) $(DEPFLAGS) $(CXXFLAGS.$(TOOLSET)) -c -o $@ $<
+
+quiet_cmd_touch = TOUCH $@
+cmd_touch = touch $@
+
+quiet_cmd_copy = COPY $@
+# send stderr to /dev/null to ignore messages when linking directories.
+cmd_copy = rm -rf "$@" && cp -af "$<" "$@"
+
+quiet_cmd_alink = AR($(TOOLSET)) $@
+cmd_alink = rm -f $@ && $(AR.$(TOOLSET)) crs $@ $(filter %.o,$^)
+
+quiet_cmd_alink_thin = AR($(TOOLSET)) $@
+cmd_alink_thin = rm -f $@ && $(AR.$(TOOLSET)) crsT $@ $(filter %.o,$^)
+
+# Due to circular dependencies between libraries :(, we wrap the
+# special "figure out circular dependencies" flags around the entire
+# input list during linking.
+quiet_cmd_link = LINK($(TOOLSET)) $@
+cmd_link = $(LINK.$(TOOLSET)) $(GYP_LDFLAGS) $(LDFLAGS.$(TOOLSET)) -o $@ -Wl,--start-group $(LD_INPUTS) -Wl,--end-group $(LIBS)
+
+# We support two kinds of shared objects (.so):
+# 1) shared_library, which is just bundling together many dependent libraries
+# into a link line.
+# 2) loadable_module, which is generating a module intended for dlopen().
+#
+# They differ only slightly:
+# In the former case, we want to package all dependent code into the .so.
+# In the latter case, we want to package just the API exposed by the
+# outermost module.
+# This means shared_library uses --whole-archive, while loadable_module doesn't.
+# (Note that --whole-archive is incompatible with the --start-group used in
+# normal linking.)
+
+# Other shared-object link notes:
+# - Set SONAME to the library filename so our binaries don't reference
+# the local, absolute paths used on the link command-line.
+quiet_cmd_solink = SOLINK($(TOOLSET)) $@
+cmd_solink = $(LINK.$(TOOLSET)) -shared $(GYP_LDFLAGS) $(LDFLAGS.$(TOOLSET)) -Wl,-soname=$(@F) -o $@ -Wl,--whole-archive $(LD_INPUTS) -Wl,--no-whole-archive $(LIBS)
+
+quiet_cmd_solink_module = SOLINK_MODULE($(TOOLSET)) $@
+cmd_solink_module = $(LINK.$(TOOLSET)) -shared $(GYP_LDFLAGS) $(LDFLAGS.$(TOOLSET)) -Wl,-soname=$(@F) -o $@ -Wl,--start-group $(filter-out FORCE_DO_CMD, $^) -Wl,--end-group $(LIBS)
+
+
+# Define an escape_quotes function to escape single quotes.
+# This allows us to handle quotes properly as long as we always use
+# use single quotes and escape_quotes.
+escape_quotes = $(subst ','\'',$(1))
+# This comment is here just to include a ' to unconfuse syntax highlighting.
+# Define an escape_vars function to escape '$' variable syntax.
+# This allows us to read/write command lines with shell variables (e.g.
+# $LD_LIBRARY_PATH), without triggering make substitution.
+escape_vars = $(subst $$,$$$$,$(1))
+# Helper that expands to a shell command to echo a string exactly as it is in
+# make. This uses printf instead of echo because printf's behaviour with respect
+# to escape sequences is more portable than echo's across different shells
+# (e.g., dash, bash).
+exact_echo = printf '%s\n' '$(call escape_quotes,$(1))'
+
+# Helper to compare the command we're about to run against the command
+# we logged the last time we ran the command.  Produces an empty
+# string (false) when the commands match.
+# Tricky point: Make has no string-equality test function.
+# The kernel uses the following, but it seems like it would have false
+# positives, where one string reordered its arguments.
+#   arg_check = $(strip $(filter-out $(cmd_$(1)), $(cmd_$@)) \
+#                       $(filter-out $(cmd_$@), $(cmd_$(1))))
+# We instead substitute each for the empty string into the other, and
+# say they're equal if both substitutions produce the empty string.
+# .d files contain ? instead of spaces, take that into account.
+command_changed = $(or $(subst $(cmd_$(1)),,$(cmd_$(call replace_spaces,$@))),\
+                       $(subst $(cmd_$(call replace_spaces,$@)),,$(cmd_$(1))))
+
+# Helper that is non-empty when a prerequisite changes.
+# Normally make does this implicitly, but we force rules to always run
+# so we can check their command lines.
+#   $? -- new prerequisites
+#   $| -- order-only dependencies
+prereq_changed = $(filter-out FORCE_DO_CMD,$(filter-out $|,$?))
+
+# Helper that executes all postbuilds until one fails.
+define do_postbuilds
+  @E=0;\
+  for p in $(POSTBUILDS); do\
+    eval $$p;\
+    E=$$?;\
+    if [ $$E -ne 0 ]; then\
+      break;\
+    fi;\
+  done;\
+  if [ $$E -ne 0 ]; then\
+    rm -rf "$@";\
+    exit $$E;\
+  fi
+endef
+
+# do_cmd: run a command via the above cmd_foo names, if necessary.
+# Should always run for a given target to handle command-line changes.
+# Second argument, if non-zero, makes it do asm/C/C++ dependency munging.
+# Third argument, if non-zero, makes it do POSTBUILDS processing.
+# Note: We intentionally do NOT call dirx for depfile, since it contains ? for
+# spaces already and dirx strips the ? characters.
+define do_cmd
+$(if $(or $(command_changed),$(prereq_changed)),
+  @$(call exact_echo,  $($(quiet)cmd_$(1)))
+  @mkdir -p "$(call dirx,$@)" "$(dir $(depfile))"
+  $(if $(findstring flock,$(word 1,$(cmd_$1))),
+    @$(cmd_$(1))
+    @echo "  $(quiet_cmd_$(1)): Finished",
+    @$(cmd_$(1))
+  )
+  @$(call exact_echo,$(call escape_vars,cmd_$(call replace_spaces,$@) := $(cmd_$(1)))) > $(depfile)
+  @$(if $(2),$(fixup_dep))
+  $(if $(and $(3), $(POSTBUILDS)),
+    $(call do_postbuilds)
+  )
+)
+endef
+
+# Declare the "all" target first so it is the default,
+# even though we don't have the deps yet.
+.PHONY: all
+all:
+
+# make looks for ways to re-generate included makefiles, but in our case, we
+# don't have a direct way. Explicitly telling make that it has nothing to do
+# for them makes it go faster.
+%.d: ;
+
+# Use FORCE_DO_CMD to force a target to run.  Should be coupled with
+# do_cmd.
+.PHONY: FORCE_DO_CMD
+FORCE_DO_CMD:
+
+TOOLSET := target
+# Suffix rules, putting all outputs into $(obj).
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.c FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.cpp FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.cxx FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.S FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(srcdir)/%.s FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+
+# Try building from generated source, too.
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.c FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.cpp FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.cxx FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.S FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(obj).$(TOOLSET)/%.s FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+
+$(obj).$(TOOLSET)/%.o: $(obj)/%.c FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(obj)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj)/%.cpp FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj)/%.cxx FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+$(obj).$(TOOLSET)/%.o: $(obj)/%.S FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+$(obj).$(TOOLSET)/%.o: $(obj)/%.s FORCE_DO_CMD
+       @$(call do_cmd,cc,1)
+
+
+ifeq ($(strip $(foreach prefix,$(NO_LOAD),\
+    $(findstring $(join ^,$(prefix)),\
+                 $(join ^,palindrome.target.mk)))),)
+  include palindrome.target.mk
+endif
+
+quiet_cmd_regen_makefile = ACTION Regenerating $@
+cmd_regen_makefile = cd $(srcdir); /usr/local/lib/node_modules/node-gyp/gyp/gyp_main.py -fmake --ignore-environment "--toplevel-dir=." -I/home/juku1999/Project/programmablewebruntime/work_suprem/owe/was/api_extensions_repo/palindromeAddon/build/config.gypi -I/usr/local/lib/node_modules/node-gyp/addon.gypi -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/common.gypi "--depth=." "-Goutput_dir=." "--generator-output=build" "-Dlibrary=shared_library" "-Dvisibility=default" "-Dnode_root_dir=/home/juku1999/.electron-gyp/.node-gyp/0.31.2" "-Dnode_gyp_dir=/usr/local/lib/node_modules/node-gyp" "-Dnode_lib_file=/home/juku1999/.electron-gyp/.node-gyp/0.31.2/<(target_arch)/node.lib" "-Dmodule_root_dir=/home/juku1999/Project/programmablewebruntime/work_suprem/owe/was/api_extensions_repo/palindromeAddon" "-Dnode_engine=v8" binding.gyp
+Makefile: $(srcdir)/../../../../../../../.electron-gyp/.node-gyp/0.31.2/common.gypi $(srcdir)/build/config.gypi $(srcdir)/binding.gyp $(srcdir)/../../../../../../../../../usr/local/lib/node_modules/node-gyp/addon.gypi
+       $(call do_cmd,regen_makefile)
+
+# "all" is a concatenation of the "all" targets from all the included
+# sub-makefiles. This is just here to clarify.
+all:
+
+# Add in dependency-tracking rules.  $(all_deps) is the list of every single
+# target in our tree. Only consider the ones with .d (dependency) info:
+d_files := $(wildcard $(foreach f,$(all_deps),$(depsdir)/$(f).d))
+ifneq ($(d_files),)
+  include $(d_files)
+endif
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome.node.d b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome.node.d
new file mode 100755 (executable)
index 0000000..aad4bd6
--- /dev/null
@@ -0,0 +1 @@
+cmd_Release/obj.target/palindrome.node := g++ -shared -pthread -rdynamic -m64  -Wl,-soname=palindrome.node -o Release/obj.target/palindrome.node -Wl,--start-group Release/obj.target/palindrome/palindrome.o -Wl,--end-group 
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome/palindrome.o.d b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/obj.target/palindrome/palindrome.o.d
new file mode 100755 (executable)
index 0000000..36167ba
--- /dev/null
@@ -0,0 +1,61 @@
+cmd_Release/obj.target/palindrome/palindrome.o := g++ '-DNODE_GYP_MODULE_NAME=palindrome' '-DUSING_UV_SHARED=1' '-DUSING_V8_SHARED=1' '-DV8_DEPRECATION_WARNINGS=1' '-D_LARGEFILE_SOURCE' '-D_FILE_OFFSET_BITS=64' '-DBUILDING_NODE_EXTENSION' -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/include/node -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include -I../../../node_modules/nan  -fPIC -pthread -Wall -Wextra -Wno-unused-parameter -m64 -O3 -ffunction-sections -fdata-sections -fno-omit-frame-pointer -fno-rtti -fno-exceptions -std=gnu++0x -MMD -MF ./Release/.deps/Release/obj.target/palindrome/palindrome.o.d.raw   -c -o Release/obj.target/palindrome/palindrome.o ../palindrome.cc
+Release/obj.target/palindrome/palindrome.o: ../palindrome.cc \
+ ../../../node_modules/nan/nan.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_version.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-errno.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-version.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-unix.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-threadpool.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-linux.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8-version.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8config.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_version.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_buffer.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node.h \
+ /home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_object_wrap.h \
+ ../../../node_modules/nan/nan_callbacks.h \
+ ../../../node_modules/nan/nan_callbacks_12_inl.h \
+ ../../../node_modules/nan/nan_maybe_43_inl.h \
+ ../../../node_modules/nan/nan_converters.h \
+ ../../../node_modules/nan/nan_converters_43_inl.h \
+ ../../../node_modules/nan/nan_new.h \
+ ../../../node_modules/nan/nan_implementation_12_inl.h \
+ ../../../node_modules/nan/nan_persistent_12_inl.h \
+ ../../../node_modules/nan/nan_weak.h \
+ ../../../node_modules/nan/nan_object_wrap.h \
+ ../../../node_modules/nan/nan_private.h \
+ ../../../node_modules/nan/nan_typedarray_contents.h \
+ ../../../node_modules/nan/nan_json.h
+../palindrome.cc:
+../../../node_modules/nan/nan.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_version.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-errno.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-version.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-unix.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-threadpool.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include/uv-linux.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8-version.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include/v8config.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_version.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_buffer.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node.h:
+/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src/node_object_wrap.h:
+../../../node_modules/nan/nan_callbacks.h:
+../../../node_modules/nan/nan_callbacks_12_inl.h:
+../../../node_modules/nan/nan_maybe_43_inl.h:
+../../../node_modules/nan/nan_converters.h:
+../../../node_modules/nan/nan_converters_43_inl.h:
+../../../node_modules/nan/nan_new.h:
+../../../node_modules/nan/nan_implementation_12_inl.h:
+../../../node_modules/nan/nan_persistent_12_inl.h:
+../../../node_modules/nan/nan_weak.h:
+../../../node_modules/nan/nan_object_wrap.h:
+../../../node_modules/nan/nan_private.h:
+../../../node_modules/nan/nan_typedarray_contents.h:
+../../../node_modules/nan/nan_json.h:
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/palindrome.node.d b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/.deps/Release/palindrome.node.d
new file mode 100755 (executable)
index 0000000..5372f97
--- /dev/null
@@ -0,0 +1 @@
+cmd_Release/palindrome.node := rm -rf "Release/palindrome.node" && cp -af "Release/obj.target/palindrome.node" "Release/palindrome.node"
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome.node b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome.node
new file mode 100755 (executable)
index 0000000..053a781
Binary files /dev/null and b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome.node differ
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome/palindrome.o b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome/palindrome.o
new file mode 100755 (executable)
index 0000000..71cc835
Binary files /dev/null and b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/obj.target/palindrome/palindrome.o differ
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/palindrome.node b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/palindrome.node
new file mode 100755 (executable)
index 0000000..053a781
Binary files /dev/null and b/wrt/wrt_support/extensions_repo/palindrome_addon/build/Release/palindrome.node differ
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/binding.Makefile b/wrt/wrt_support/extensions_repo/palindrome_addon/build/binding.Makefile
new file mode 100755 (executable)
index 0000000..48623c0
--- /dev/null
@@ -0,0 +1,6 @@
+# This file is generated by gyp; do not edit.
+
+export builddir_name ?= ./build/.
+.PHONY: all
+all:
+       $(MAKE) palindrome
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/config.gypi b/wrt/wrt_support/extensions_repo/palindrome_addon/build/config.gypi
new file mode 100755 (executable)
index 0000000..6ef10ad
--- /dev/null
@@ -0,0 +1,71 @@
+# Do not edit. File was generated by node-gyp's "configure" step
+{
+  "target_defaults": {
+    "cflags": [],
+    "default_configuration": "Release",
+    "defines": [],
+    "include_dirs": [],
+    "libraries": []
+  },
+  "variables": {
+    "asan": 0,
+    "coverage": "false",
+    "debug_devtools": "node",
+    "debug_http2": "false",
+    "debug_nghttp2": "false",
+    "force_dynamic_crt": 0,
+    "gas_version": "2.24",
+    "host_arch": "x64",
+    "icu_data_file": "icudt59l.dat",
+    "icu_data_in": "../../deps/icu-small/source/data/in/icudt59l.dat",
+    "icu_endianness": "l",
+    "icu_gyp_path": "tools/icu/icu-generic.gyp",
+    "icu_locales": "en,root",
+    "icu_path": "deps/icu-small",
+    "icu_small": "true",
+    "icu_ver_major": "59",
+    "node_byteorder": "little",
+    "node_enable_d8": "false",
+    "node_enable_v8_vtunejit": "false",
+    "node_install_npm": "true",
+    "node_module_version": 57,
+    "node_no_browser_globals": "false",
+    "node_prefix": "/usr/local",
+    "node_release_urlbase": "",
+    "node_shared": "false",
+    "node_shared_cares": "false",
+    "node_shared_http_parser": "false",
+    "node_shared_libuv": "false",
+    "node_shared_openssl": "false",
+    "node_shared_zlib": "false",
+    "node_tag": "",
+    "node_use_bundled_v8": "true",
+    "node_use_dtrace": "false",
+    "node_use_etw": "false",
+    "node_use_lttng": "false",
+    "node_use_openssl": "true",
+    "node_use_perfctr": "false",
+    "node_use_v8_platform": "true",
+    "node_without_node_options": "false",
+    "openssl_fips": "",
+    "openssl_no_asm": 0,
+    "shlib_suffix": "so.57",
+    "target_arch": "x64",
+    "uv_parent_path": "/deps/uv/",
+    "uv_use_dtrace": "false",
+    "v8_enable_gdbjit": 0,
+    "v8_enable_i18n_support": 1,
+    "v8_enable_inspector": 1,
+    "v8_no_strict_aliasing": 1,
+    "v8_optimized_debug": 0,
+    "v8_promise_internal_field_count": 1,
+    "v8_random_seed": 0,
+    "v8_trace_maps": 0,
+    "v8_use_snapshot": "false",
+    "want_separate_host_toolset": 0,
+    "want_separate_host_toolset_mkpeephole": 0,
+    "nodedir": "/home/juku1999/.electron-gyp/.node-gyp/0.31.2",
+    "standalone_static_library": 1,
+    "target": "0.31.2"
+  }
+}
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/build/palindrome.target.mk b/wrt/wrt_support/extensions_repo/palindrome_addon/build/palindrome.target.mk
new file mode 100755 (executable)
index 0000000..de10c33
--- /dev/null
@@ -0,0 +1,144 @@
+# This file is generated by gyp; do not edit.
+
+TOOLSET := target
+TARGET := palindrome
+DEFS_Debug := \
+       '-DNODE_GYP_MODULE_NAME=palindrome' \
+       '-DUSING_UV_SHARED=1' \
+       '-DUSING_V8_SHARED=1' \
+       '-DV8_DEPRECATION_WARNINGS=1' \
+       '-D_LARGEFILE_SOURCE' \
+       '-D_FILE_OFFSET_BITS=64' \
+       '-DBUILDING_NODE_EXTENSION' \
+       '-DDEBUG' \
+       '-D_DEBUG'
+
+# Flags passed to all source files.
+CFLAGS_Debug := \
+       -fPIC \
+       -pthread \
+       -Wall \
+       -Wextra \
+       -Wno-unused-parameter \
+       -m64 \
+       -g \
+       -O0
+
+# Flags passed to only C files.
+CFLAGS_C_Debug :=
+
+# Flags passed to only C++ files.
+CFLAGS_CC_Debug := \
+       -fno-rtti \
+       -fno-exceptions \
+       -std=gnu++0x
+
+INCS_Debug := \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/include/node \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include \
+       -I$(srcdir)/../../node_modules/nan
+
+DEFS_Release := \
+       '-DNODE_GYP_MODULE_NAME=palindrome' \
+       '-DUSING_UV_SHARED=1' \
+       '-DUSING_V8_SHARED=1' \
+       '-DV8_DEPRECATION_WARNINGS=1' \
+       '-D_LARGEFILE_SOURCE' \
+       '-D_FILE_OFFSET_BITS=64' \
+       '-DBUILDING_NODE_EXTENSION'
+
+# Flags passed to all source files.
+CFLAGS_Release := \
+       -fPIC \
+       -pthread \
+       -Wall \
+       -Wextra \
+       -Wno-unused-parameter \
+       -m64 \
+       -O3 \
+       -ffunction-sections \
+       -fdata-sections \
+       -fno-omit-frame-pointer
+
+# Flags passed to only C files.
+CFLAGS_C_Release :=
+
+# Flags passed to only C++ files.
+CFLAGS_CC_Release := \
+       -fno-rtti \
+       -fno-exceptions \
+       -std=gnu++0x
+
+INCS_Release := \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/include/node \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/src \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/uv/include \
+       -I/home/juku1999/.electron-gyp/.node-gyp/0.31.2/deps/v8/include \
+       -I$(srcdir)/../../node_modules/nan
+
+OBJS := \
+       $(obj).target/$(TARGET)/palindrome.o
+
+# Add to the list of files we specially track dependencies for.
+all_deps += $(OBJS)
+
+# CFLAGS et al overrides must be target-local.
+# See "Target-specific Variable Values" in the GNU Make manual.
+$(OBJS): TOOLSET := $(TOOLSET)
+$(OBJS): GYP_CFLAGS := $(DEFS_$(BUILDTYPE)) $(INCS_$(BUILDTYPE))  $(CFLAGS_$(BUILDTYPE)) $(CFLAGS_C_$(BUILDTYPE))
+$(OBJS): GYP_CXXFLAGS := $(DEFS_$(BUILDTYPE)) $(INCS_$(BUILDTYPE))  $(CFLAGS_$(BUILDTYPE)) $(CFLAGS_CC_$(BUILDTYPE))
+
+# Suffix rules, putting all outputs into $(obj).
+
+$(obj).$(TOOLSET)/$(TARGET)/%.o: $(srcdir)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+
+# Try building from generated source, too.
+
+$(obj).$(TOOLSET)/$(TARGET)/%.o: $(obj).$(TOOLSET)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+
+$(obj).$(TOOLSET)/$(TARGET)/%.o: $(obj)/%.cc FORCE_DO_CMD
+       @$(call do_cmd,cxx,1)
+
+# End of this set of suffix rules
+### Rules for final target.
+LDFLAGS_Debug := \
+       -pthread \
+       -rdynamic \
+       -m64
+
+LDFLAGS_Release := \
+       -pthread \
+       -rdynamic \
+       -m64
+
+LIBS :=
+
+$(obj).target/palindrome.node: GYP_LDFLAGS := $(LDFLAGS_$(BUILDTYPE))
+$(obj).target/palindrome.node: LIBS := $(LIBS)
+$(obj).target/palindrome.node: TOOLSET := $(TOOLSET)
+$(obj).target/palindrome.node: $(OBJS) FORCE_DO_CMD
+       $(call do_cmd,solink_module)
+
+all_deps += $(obj).target/palindrome.node
+# Add target alias
+.PHONY: palindrome
+palindrome: $(builddir)/palindrome.node
+
+# Copy this to the executable output path.
+$(builddir)/palindrome.node: TOOLSET := $(TOOLSET)
+$(builddir)/palindrome.node: $(obj).target/palindrome.node FORCE_DO_CMD
+       $(call do_cmd,copy)
+
+all_deps += $(builddir)/palindrome.node
+# Short alias for building this executable.
+.PHONY: palindrome.node
+palindrome.node: $(obj).target/palindrome.node $(builddir)/palindrome.node
+
+# Add executable to "all" target.
+.PHONY: all
+all: $(builddir)/palindrome.node
+
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/package.json b/wrt/wrt_support/extensions_repo/palindrome_addon/package.json
new file mode 100755 (executable)
index 0000000..084d882
--- /dev/null
@@ -0,0 +1,30 @@
+{
+  "name": "palindrome_addon",
+  "version": "0.1.1",
+  "gypfile": true,
+  "description": "Know if a string is a palindrome using Node.js with C++ native implementation",
+  "main": "palindrome.js",  
+  "type": "addon",
+  "scripts": {
+    "start": "node-gyp build && node palindrome.js",
+    "test": "mocha"
+  },
+  "repository": {
+    "type": "git",
+    "url": "git+https://github.com/zzarcon/palindrome.git"
+  },
+  "author": "zzarcon",
+  "license": "MIT",
+  "bugs": {
+    "url": "https://github.com/zzarcon/palindrome/issues"
+  },
+  "homepage": "https://github.com/zzarcon/palindrome#readme",
+  "dependencies": {
+    "bindings": "^1.2.1",
+    "nan": "^2.3.4"
+  },
+  "devDependencies": {
+    "mocha": "^3.2.0",
+    "relaser": "^0.2.0"
+  }
+}
diff --git a/wrt/wrt_support/extensions_repo/palindrome_addon/palindrome.cc b/wrt/wrt_support/extensions_repo/palindrome_addon/palindrome.cc
new file mode 100755 (executable)
index 0000000..f3a48ca
--- /dev/null
@@ -0,0 +1,42 @@
+#include <nan.h>
+
+using namespace v8;
+
+void IsPalindrome(const FunctionCallbackInfo<Value>& info) {
+  Nan::Utf8String arg0(info[0]);
+  char *str = *arg0;
+  size_t len = arg0.length();
+  int half = len / 2;
+  int start = 0;
+  int end = len - 1;
+  int space = 32;
+  int comma = 44;
+  bool isPal = true;
+  bool startSpace;
+  bool endSpace;
+
+  while (half > 0 && isPal) {
+    startSpace = str[start] == space || str[start] == comma;
+    endSpace = str[end] == space || str[end] == comma;
+
+    if (str[start] == str[end]) {
+      start++;
+      end--;
+    } else if (startSpace || endSpace) {
+      startSpace && start++;
+      endSpace && end--;
+    } else {
+      isPal = false;
+    }
+
+    half--;
+  }
+
+  info.GetReturnValue().Set(isPal);
+}
+
+void Init(Local<Object> exports, Local<Object> module) {
+  NODE_SET_METHOD(module, "exports", IsPalindrome);
+}
+
+NODE_MODULE(addon, Init)
diff --git a/wrt/wrt_support/sample/wgt/PalindromeTest.wgt b/wrt/wrt_support/sample/wgt/PalindromeTest.wgt
new file mode 100755 (executable)
index 0000000..61c326b
Binary files /dev/null and b/wrt/wrt_support/sample/wgt/PalindromeTest.wgt differ