Merge lp:~manishsinha/zeitgeist-datasources/reworked-tomboy into lp:zeitgeist-datasources/0.8
- reworked-tomboy
- Merge into trunk
Status: | Superseded |
---|---|
Proposed branch: | lp:~manishsinha/zeitgeist-datasources/reworked-tomboy |
Merge into: | lp:zeitgeist-datasources/0.8 |
Diff against target: |
962 lines (+528/-247) 13 files modified
Makefile.include (+118/-0) configure.ac (+28/-4) tomboy/AssemblyInfo.cs (+27/-0) tomboy/Makefile.am (+103/-0) tomboy/NoteHandler.cs (+69/-0) tomboy/Tomboy.Zeitgeist.csproj (+65/-0) tomboy/Tomboy.Zeitgeist.sln (+20/-0) tomboy/Zeitgeist.addin.xml (+2/-2) tomboy/Zeitgeist.cs (+0/-200) tomboy/Zeitgeist.mdp (+0/-28) tomboy/ZeitgeistAddin.cs (+90/-0) tomboy/install.sh (+0/-13) tomboy/tomboy.zeitgeist.pc (+6/-0) |
To merge this branch: | bzr merge lp:~manishsinha/zeitgeist-datasources/reworked-tomboy |
Related bugs: |
Reviewer | Review Type | Date Requested | Status |
---|---|---|---|
Michal Hruby | Pending | ||
Review via email: mp+35955@code.launchpad.net |
This proposal supersedes a proposal from 2010-09-19.
This proposal has been superseded by a proposal from 2010-09-19.
Commit message
Description of the change
Reimplemented Tomboy's data provider using zeitgeist-sharp
http://
Michal Hruby (mhr3) wrote : Posted in a previous version of this proposal | # |
Manish Sinha (मनीष सिन्हा) (manishsinha) wrote : Posted in a previous version of this proposal | # |
> From a quick look (I'm not using Tomboy):
> - 'TomboyUri' should be just application:
Doing it.
> - please get rid of the install.sh script, everything is now done using
> Makefiles
Yeah. Have to get it working. I just kept the old way of building.
> - I really don't like the bundled dll library, isn't there another way to
> check for it?
Until zeitgeist-sharp is not made available in the PPA/Repo, till then we have to keep it here. Once it is made available, then we can get rid of this. BTW this bundled dll is just a workaround till zg-sharp makes it into APT repo
- 93. By Manish Sinha (मनीष सिन्हा)
-
Modified build to include tomboy too
- 94. By Manish Sinha (मनीष सिन्हा)
-
Removed the old mdp based builds
Unmerged revisions
- 94. By Manish Sinha (मनीष सिन्हा)
-
Removed the old mdp based builds
- 93. By Manish Sinha (मनीष सिन्हा)
-
Modified build to include tomboy too
- 92. By Manish Sinha (मनीष सिन्हा)
-
Added Simple Makefile support with most common targets. The config script does the basic package dependency checking
- 91. By Manish Sinha (मनीष सिन्हा)
-
Changed the App name to application:
//tomboy. desktop and created a sln file - 90. By Manish Sinha (मनीष सिन्हा)
-
Implemented Note open, closed, deleted, hidden and renamed
Zeitgeist.dll is added in the source control. Once it is packages and available in the APT repos, it can be removed from the source code
- 89. By Manish Sinha (मनीष सिन्हा)
-
Created the basic infrastructure for using Zeitgeist.dll. At present Logging is not implemented
Preview Diff
1 | === added file 'Makefile.include' | |||
2 | --- Makefile.include 1970-01-01 00:00:00 +0000 | |||
3 | +++ Makefile.include 2010-09-19 19:01:06 +0000 | |||
4 | @@ -0,0 +1,118 @@ | |||
5 | 1 | VALID_CULTURES = ar bg ca zh-CHS cs da de el en es fi fr he hu is it ja ko nl no pl pt ro ru hr sk sq sv th tr id uk be sl et lv lt fa vi hy eu mk af ka fo hi sw gu ta te kn mr gl kok ar-SA bg-BG ca-ES zh-TW cs-CZ da-DK de-DE el-GR en-US fi-FI fr-FR he-IL hu-HU is-IS it-IT ja-JP ko-KR nl-NL nb-NO pl-PL pt-BR ro-RO ru-RU hr-HR sk-SK sq-AL sv-SE th-TH tr-TR id-ID uk-UA be-BY sl-SI et-EE lv-LV lt-LT fa-IR vi-VN hy-AM eu-ES mk-MK af-ZA ka-GE fo-FO hi-IN sw-KE gu-IN ta-IN te-IN kn-IN mr-IN gl-ES kok-IN ar-IQ zh-CN de-CH en-GB es-MX fr-BE it-CH nl-BE nn-NO pt-PT sv-FI ar-EG zh-HK de-AT en-AU es-ES fr-CA ar-LY zh-SG de-LU en-CA es-GT fr-CH ar-DZ zh-MO en-NZ es-CR fr-LU ar-MA en-IE es-PA ar-TN en-ZA es-DO ar-OM es-VE ar-YE es-CO ar-SY es-PE ar-JO en-TT es-AR ar-LB en-ZW es-EC ar-KW en-PH es-CL ar-AE es-UY ar-BH es-PY ar-QA es-BO es-SV es-HN es-NI es-PR zh-CHT | ||
6 | 2 | |||
7 | 3 | s2q=$(subst \ ,?,$1) | ||
8 | 4 | q2s=$(subst ?,\ ,$1) | ||
9 | 5 | # use this when result will be quoted | ||
10 | 6 | unesc2=$(subst ?, ,$1) | ||
11 | 7 | |||
12 | 8 | build_sources = $(FILES) $(GENERATED_FILES) | ||
13 | 9 | build_sources_esc= $(call s2q,$(build_sources)) | ||
14 | 10 | # use unesc2, as build_sources_embed is quoted | ||
15 | 11 | build_sources_embed= $(call unesc2,$(build_sources_esc:%='$(srcdir)/%')) | ||
16 | 12 | |||
17 | 13 | comma__=, | ||
18 | 14 | get_resource_name = $(firstword $(subst $(comma__), ,$1)) | ||
19 | 15 | get_culture = $(lastword $(subst ., ,$(basename $1))) | ||
20 | 16 | is_cultured_resource = $(and $(word 3,$(subst ., ,$1)), $(filter $(VALID_CULTURES),$(lastword $(subst ., ,$(basename $1))))) | ||
21 | 17 | |||
22 | 18 | RESOURCES_ESC=$(call s2q,$(RESOURCES)) | ||
23 | 19 | |||
24 | 20 | build_resx_list = $(foreach res, $(RESOURCES_ESC), $(if $(filter %.resx, $(call get_resource_name,$(res))),$(res),)) | ||
25 | 21 | build_non_culture_resx_list = $(foreach res, $(build_resx_list),$(if $(call is_cultured_resource,$(call get_resource_name,$(res))),,$(res))) | ||
26 | 22 | build_non_culture_others_list = $(foreach res, $(filter-out $(build_resx_list),$(RESOURCES_ESC)),$(if $(call is_cultured_resource,$(call get_resource_name,$(res))),,$(res))) | ||
27 | 23 | build_others_list = $(build_non_culture_others_list) | ||
28 | 24 | build_xamlg_list = $(filter %.xaml.g.cs, $(FILES)) | ||
29 | 25 | |||
30 | 26 | # resgen all .resx resources | ||
31 | 27 | build_resx_files = $(foreach res, $(build_resx_list), $(call get_resource_name,$(res))) | ||
32 | 28 | build_resx_resources_esc = $(build_resx_files:.resx=.resources) | ||
33 | 29 | build_resx_resources = $(call q2s,$(build_resx_resources_esc)) | ||
34 | 30 | |||
35 | 31 | # embed resources for the main assembly | ||
36 | 32 | build_resx_resources_hack = $(subst .resx,.resources, $(build_non_culture_resx_list)) | ||
37 | 33 | # use unesc2, as build_resx_resources_embed is quoted | ||
38 | 34 | build_resx_resources_embed = $(call unesc2,$(build_resx_resources_hack:%='-resource:%')) | ||
39 | 35 | build_others_files = $(call q2s,$(foreach res, $(build_others_list),$(call get_resource_name,$(res)))) | ||
40 | 36 | build_others_resources = $(build_others_files) | ||
41 | 37 | # use unesc2, as build_others_resources_embed is quoted | ||
42 | 38 | build_others_resources_embed = $(call unesc2,$(build_others_list:%='-resource:$(srcdir)/%')) | ||
43 | 39 | |||
44 | 40 | build_resources = $(build_resx_resources) $(build_others_resources) | ||
45 | 41 | build_resources_embed = $(build_resx_resources_embed) $(build_others_resources_embed) | ||
46 | 42 | |||
47 | 43 | # -usesourcepath is available only for resgen2 | ||
48 | 44 | emit_resgen_target_1=$(call q2s,$1) : $(call q2s,$(subst .resources,.resx,$1)); cd '$$(shell dirname '$$<')' && MONO_IOMAP=drive $$(RESGEN) '$$(shell basename '$$<')' '$$(shell basename '$$@')' | ||
49 | 45 | emit_resgen_target_2=$(call q2s,$1) : $(call q2s,$(subst .resources,.resx,$1)); MONO_IOMAP=drive $$(RESGEN) -usesourcepath '$$<' '$$@' | ||
50 | 46 | |||
51 | 47 | emit_resgen_target=$(if $(filter resgen2,$(RESGEN)),$(emit_resgen_target_2),$(emit_resgen_target_1)) | ||
52 | 48 | emit_resgen_targets=$(foreach res,$(build_resx_resources_esc),$(eval $(call emit_resgen_target,$(res)))) | ||
53 | 49 | |||
54 | 50 | build_references_ref = $(call q2s,$(foreach ref, $(call s2q,$(REFERENCES)), $(if $(filter -pkg:%, $(ref)), $(ref), $(if $(filter -r:%, $(ref)), $(ref), -r:$(ref))))) | ||
55 | 51 | build_references_ref += $(call q2s,$(foreach ref, $(call s2q,$(DLL_REFERENCES)), -r:$(ref))) | ||
56 | 52 | build_references_ref += $(call q2s,$(foreach ref, $(call s2q,$(PROJECT_REFERENCES)), -r:$(ref))) | ||
57 | 53 | |||
58 | 54 | s2q2s=$(call unesc2,$(call s2q,$1)) | ||
59 | 55 | cp_actual=test -z $1 || cp $1 $2 | ||
60 | 56 | cp=$(call cp_actual,'$(call s2q2s,$1)','$(call s2q2s,$2)') | ||
61 | 57 | |||
62 | 58 | rm_actual=test -z '$1' || rm -f '$2' | ||
63 | 59 | rm=$(call rm_actual,$(call s2q2s,$1),$(call s2q2s,$2)/$(shell basename '$(call s2q2s,$1)')) | ||
64 | 60 | |||
65 | 61 | EXTRA_DIST += $(build_sources) $(build_resx_files) $(build_others_files) $(ASSEMBLY_WRAPPER_IN) $(EXTRAS) $(DATA_FILES) $(build_culture_res_files) | ||
66 | 62 | CLEANFILES += $(ASSEMBLY) $(ASSEMBLY).mdb $(BINARIES) $(build_resx_resources) $(build_satellite_assembly_list) | ||
67 | 63 | DISTCLEANFILES = $(GENERATED_FILES) $(pc_files) $(BUILD_DIR)/* | ||
68 | 64 | |||
69 | 65 | pkglib_SCRIPTS = $(ASSEMBLY) | ||
70 | 66 | bin_SCRIPTS = $(BINARIES) | ||
71 | 67 | |||
72 | 68 | programfilesdir = @libdir@/@PACKAGE@ | ||
73 | 69 | programfiles_DATA = $(PROGRAMFILES) | ||
74 | 70 | linuxpkgconfigdir = @libdir@/pkgconfig | ||
75 | 71 | linuxpkgconfig_DATA = $(LINUX_PKGCONFIG) | ||
76 | 72 | |||
77 | 73 | |||
78 | 74 | # macros | ||
79 | 75 | |||
80 | 76 | # $(call emit-deploy-target,deploy-variable-name) | ||
81 | 77 | define emit-deploy-target | ||
82 | 78 | $($1): $($1_SOURCE) | ||
83 | 79 | mkdir -p '$$(shell dirname '$$@')' | ||
84 | 80 | cp '$$<' '$$@' | ||
85 | 81 | endef | ||
86 | 82 | |||
87 | 83 | # $(call emit-deploy-wrapper,wrapper-variable-name,wrapper-sourcefile,x) | ||
88 | 84 | # assumes that for a wrapper foo.pc its source template is foo.pc.in | ||
89 | 85 | # if $3 is non-empty then wrapper is marked exec | ||
90 | 86 | define emit-deploy-wrapper | ||
91 | 87 | $($1): $2 | ||
92 | 88 | mkdir -p '$$(shell dirname '$$@')' | ||
93 | 89 | cp '$$<' '$$@' | ||
94 | 90 | $(if $3,chmod +x '$$@') | ||
95 | 91 | |||
96 | 92 | endef | ||
97 | 93 | |||
98 | 94 | # generating satellite assemblies | ||
99 | 95 | |||
100 | 96 | culture_resources = $(foreach res, $(RESOURCES_ESC), $(if $(call is_cultured_resource,$(call get_resource_name, $(res))),$(res))) | ||
101 | 97 | cultures = $(sort $(foreach res, $(culture_resources), $(call get_culture,$(call get_resource_name,$(res))))) | ||
102 | 98 | culture_resource_dependencies = $(call q2s,$(BUILD_DIR)/$1/$(SATELLITE_ASSEMBLY_NAME): $(subst .resx,.resources,$2)) | ||
103 | 99 | culture_resource_commandlines = $(call unesc2,cmd_line_satellite_$1 += '/embed:$(subst .resx,.resources,$2)') | ||
104 | 100 | build_satellite_assembly_list = $(call q2s,$(cultures:%=$(BUILD_DIR)/%/$(SATELLITE_ASSEMBLY_NAME))) | ||
105 | 101 | build_culture_res_files = $(call q2s,$(foreach res, $(culture_resources),$(call get_resource_name,$(res)))) | ||
106 | 102 | install_satellite_assembly_list = $(subst $(BUILD_DIR),$(DESTDIR)$(libdir)/$(PACKAGE),$(build_satellite_assembly_list)) | ||
107 | 103 | |||
108 | 104 | $(eval $(foreach res, $(culture_resources), $(eval $(call culture_resource_dependencies,$(call get_culture,$(call get_resource_name,$(res))),$(call get_resource_name,$(res)))))) | ||
109 | 105 | $(eval $(foreach res, $(culture_resources), $(eval $(call culture_resource_commandlines,$(call get_culture,$(call get_resource_name,$(res))),$(res))))) | ||
110 | 106 | |||
111 | 107 | $(build_satellite_assembly_list): $(BUILD_DIR)/%/$(SATELLITE_ASSEMBLY_NAME): | ||
112 | 108 | mkdir -p '$(@D)' | ||
113 | 109 | $(AL) -out:'$@' -culture:$* -t:lib $(cmd_line_satellite_$*) | ||
114 | 110 | |||
115 | 111 | $(install_satellite_assembly_list): | ||
116 | 112 | mkdir -p '$(@D)' | ||
117 | 113 | cp $(subst $(DESTDIR)$(libdir)/$(PACKAGE), $(BUILD_DIR), $@) $@ | ||
118 | 114 | |||
119 | 115 | install-satellite-assemblies: $(install_satellite_assembly_list) | ||
120 | 116 | |||
121 | 117 | uninstall-satellite-assemblies: | ||
122 | 118 | rm -rf $(install_satellite_assembly_list) | ||
123 | 0 | \ No newline at end of file | 119 | \ No newline at end of file |
124 | 1 | 120 | ||
125 | === modified file 'configure.ac' | |||
126 | --- configure.ac 2010-08-05 20:45:47 +0000 | |||
127 | +++ configure.ac 2010-09-19 19:01:06 +0000 | |||
128 | @@ -51,8 +51,8 @@ | |||
129 | 51 | AC_MSG_RESULT($all_plugins) | 51 | AC_MSG_RESULT($all_plugins) |
130 | 52 | 52 | ||
131 | 53 | # The full list of plugins | 53 | # The full list of plugins |
134 | 54 | allowed_plugins="bzr chrome eog firefox-libzg geany gedit rhythmbox totem-libzg vim emacs" | 54 | allowed_plugins="bzr chrome eog firefox-libzg geany gedit rhythmbox totem-libzg vim emacs tomboy" |
135 | 55 | # currently disabled = "epiphany tomboy" | 55 | # currently disabled = "epiphany" |
136 | 56 | 56 | ||
137 | 57 | # npapi-plugin has a template Makefile.am, but don't use it directly | 57 | # npapi-plugin has a template Makefile.am, but don't use it directly |
138 | 58 | # - see chrome's Makefile.am for how to compile it | 58 | # - see chrome's Makefile.am for how to compile it |
139 | @@ -152,8 +152,31 @@ | |||
140 | 152 | fi | 152 | fi |
141 | 153 | ;; | 153 | ;; |
142 | 154 | tomboy) | 154 | tomboy) |
145 | 155 | # not supported atm | 155 | AC_PATH_PROG(GMCS, gmcs, no) |
146 | 156 | continue | 156 | PKG_CHECK_MODULES([GTK_SHARP_20], [gtk-sharp-2.0]) |
147 | 157 | if test "x$GMCS" = "xno"; then | ||
148 | 158 | AC_MSG_ERROR([gmcs Not found]) | ||
149 | 159 | fi | ||
150 | 160 | AC_ARG_ENABLE(debug, | ||
151 | 161 | AC_HELP_STRING([--enable-debug], | ||
152 | 162 | [Use 'DEBUG' Configuration [default=NO]]), | ||
153 | 163 | enable_debug=yes, enable_debug=no) | ||
154 | 164 | AM_CONDITIONAL(ENABLE_DEBUG, test x$enable_debug = xyes) | ||
155 | 165 | if test "x$enable_debug" = "xyes" ; then | ||
156 | 166 | CONFIG_REQUESTED="yes" | ||
157 | 167 | fi | ||
158 | 168 | AC_ARG_ENABLE(release, | ||
159 | 169 | AC_HELP_STRING([--enable-release], | ||
160 | 170 | [Use 'RELEASE' Configuration [default=YES]]), | ||
161 | 171 | enable_release=yes, enable_release=no) | ||
162 | 172 | AM_CONDITIONAL(ENABLE_RELEASE, test x$enable_release = xyes) | ||
163 | 173 | if test "x$enable_release" = "xyes" ; then | ||
164 | 174 | CONFIG_REQUESTED="yes" | ||
165 | 175 | fi | ||
166 | 176 | if test -z "$CONFIG_REQUESTED" ; then | ||
167 | 177 | AM_CONDITIONAL(ENABLE_RELEASE, true) | ||
168 | 178 | enable_release=yes | ||
169 | 179 | fi | ||
170 | 157 | ;; | 180 | ;; |
171 | 158 | totem*) | 181 | totem*) |
172 | 159 | if test "${with_vala}" != "yes" ; then | 182 | if test "${with_vala}" != "yes" ; then |
173 | @@ -217,6 +240,7 @@ | |||
174 | 217 | totem-libzg/Makefile | 240 | totem-libzg/Makefile |
175 | 218 | vim/Makefile | 241 | vim/Makefile |
176 | 219 | emacs/Makefile | 242 | emacs/Makefile |
177 | 243 | tomboy/Makefile | ||
178 | 220 | ]) | 244 | ]) |
179 | 221 | 245 | ||
180 | 222 | AC_MSG_NOTICE([Zeitgeist-dataproviders was configured with the following options:]) | 246 | AC_MSG_NOTICE([Zeitgeist-dataproviders was configured with the following options:]) |
181 | 223 | 247 | ||
182 | === added file 'tomboy/AssemblyInfo.cs' | |||
183 | --- tomboy/AssemblyInfo.cs 1970-01-01 00:00:00 +0000 | |||
184 | +++ tomboy/AssemblyInfo.cs 2010-09-19 19:01:06 +0000 | |||
185 | @@ -0,0 +1,27 @@ | |||
186 | 1 | using System.Reflection; | ||
187 | 2 | using System.Runtime.CompilerServices; | ||
188 | 3 | |||
189 | 4 | // Information about this assembly is defined by the following attributes. | ||
190 | 5 | // Change them to the values specific to your project. | ||
191 | 6 | |||
192 | 7 | [assembly: AssemblyTitle("Tomboy.Zeitgeist")] | ||
193 | 8 | [assembly: AssemblyDescription("")] | ||
194 | 9 | [assembly: AssemblyConfiguration("")] | ||
195 | 10 | [assembly: AssemblyCompany("")] | ||
196 | 11 | [assembly: AssemblyProduct("")] | ||
197 | 12 | [assembly: AssemblyCopyright("Zeitgeist Sharp Developers")] | ||
198 | 13 | [assembly: AssemblyTrademark("")] | ||
199 | 14 | [assembly: AssemblyCulture("")] | ||
200 | 15 | |||
201 | 16 | // The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}". | ||
202 | 17 | // The form "{Major}.{Minor}.*" will automatically update the build and revision, | ||
203 | 18 | // and "{Major}.{Minor}.{Build}.*" will update just the revision. | ||
204 | 19 | |||
205 | 20 | [assembly: AssemblyVersion("0.1.0.*")] | ||
206 | 21 | |||
207 | 22 | // The following attributes are used to specify the signing key for the assembly, | ||
208 | 23 | // if desired. See the Mono documentation for more information about signing. | ||
209 | 24 | |||
210 | 25 | //[assembly: AssemblyDelaySign(false)] | ||
211 | 26 | //[assembly: AssemblyKeyFile("")] | ||
212 | 27 | |||
213 | 0 | 28 | ||
214 | === added file 'tomboy/Makefile.am' | |||
215 | --- tomboy/Makefile.am 1970-01-01 00:00:00 +0000 | |||
216 | +++ tomboy/Makefile.am 2010-09-19 19:01:06 +0000 | |||
217 | @@ -0,0 +1,103 @@ | |||
218 | 1 | |||
219 | 2 | EXTRA_DIST = expansions.m4 /usr/lib/tomboy/Tomboy.exe Zeitgeist.dll | ||
220 | 3 | |||
221 | 4 | #Warning: This is an automatically generated file, do not edit! | ||
222 | 5 | if ENABLE_DEBUG | ||
223 | 6 | SUBDIRS = . | ||
224 | 7 | endif | ||
225 | 8 | if ENABLE_RELEASE | ||
226 | 9 | SUBDIRS = . | ||
227 | 10 | endif | ||
228 | 11 | |||
229 | 12 | |||
230 | 13 | |||
231 | 14 | # Warning: This is an automatically generated file, do not edit! | ||
232 | 15 | |||
233 | 16 | if ENABLE_DEBUG | ||
234 | 17 | ASSEMBLY_COMPILER_COMMAND = gmcs | ||
235 | 18 | ASSEMBLY_COMPILER_FLAGS = -noconfig -codepage:utf8 -warn:4 -optimize- -debug "-define:DEBUG" | ||
236 | 19 | ASSEMBLY = bin/Debug/Tomboy.Zeitgeist.dll | ||
237 | 20 | ASSEMBLY_MDB = $(ASSEMBLY).mdb | ||
238 | 21 | COMPILE_TARGET = library | ||
239 | 22 | PROJECT_REFERENCES = | ||
240 | 23 | BUILD_DIR = bin/Debug | ||
241 | 24 | |||
242 | 25 | ZEITGEIST_DLL_SOURCE=Zeitgeist.dll | ||
243 | 26 | TOMBOY_ZEITGEIST_DLL_MDB_SOURCE=bin/Debug/Tomboy.Zeitgeist.dll.mdb | ||
244 | 27 | TOMBOY_ZEITGEIST_DLL_MDB=$(BUILD_DIR)/Tomboy.Zeitgeist.dll.mdb | ||
245 | 28 | |||
246 | 29 | endif | ||
247 | 30 | |||
248 | 31 | if ENABLE_RELEASE | ||
249 | 32 | ASSEMBLY_COMPILER_COMMAND = gmcs | ||
250 | 33 | ASSEMBLY_COMPILER_FLAGS = -noconfig -codepage:utf8 -warn:4 -optimize- | ||
251 | 34 | ASSEMBLY = bin/Release/Tomboy.Zeitgeist.dll | ||
252 | 35 | ASSEMBLY_MDB = | ||
253 | 36 | COMPILE_TARGET = library | ||
254 | 37 | PROJECT_REFERENCES = | ||
255 | 38 | BUILD_DIR = bin/Release | ||
256 | 39 | |||
257 | 40 | ZEITGEIST_DLL_SOURCE=Zeitgeist.dll | ||
258 | 41 | TOMBOY_ZEITGEIST_DLL_MDB= | ||
259 | 42 | |||
260 | 43 | endif | ||
261 | 44 | |||
262 | 45 | AL=al2 | ||
263 | 46 | SATELLITE_ASSEMBLY_NAME=$(notdir $(basename $(ASSEMBLY))).resources.dll | ||
264 | 47 | |||
265 | 48 | PROGRAMFILES = \ | ||
266 | 49 | $(ZEITGEIST_DLL) \ | ||
267 | 50 | $(TOMBOY_ZEITGEIST_DLL_MDB) | ||
268 | 51 | |||
269 | 52 | LINUX_PKGCONFIG = \ | ||
270 | 53 | $(TOMBOY_ZEITGEIST_PC) | ||
271 | 54 | |||
272 | 55 | |||
273 | 56 | RESGEN=resgen2 | ||
274 | 57 | |||
275 | 58 | all: $(ASSEMBLY) $(PROGRAMFILES) $(LINUX_PKGCONFIG) | ||
276 | 59 | |||
277 | 60 | FILES = \ | ||
278 | 61 | AssemblyInfo.cs \ | ||
279 | 62 | ZeitgeistAddin.cs \ | ||
280 | 63 | NoteHandler.cs \ | ||
281 | 64 | Zeitgeist.cs | ||
282 | 65 | |||
283 | 66 | DATA_FILES = | ||
284 | 67 | |||
285 | 68 | RESOURCES = \ | ||
286 | 69 | Zeitgeist.addin.xml,Tomboy.Zeitgeist.Zeitgeist.addin.xml | ||
287 | 70 | |||
288 | 71 | EXTRAS = \ | ||
289 | 72 | tomboy.zeitgeist.pc.in | ||
290 | 73 | |||
291 | 74 | REFERENCES = \ | ||
292 | 75 | System \ | ||
293 | 76 | $(GTK_SHARP_20_LIBS) \ | ||
294 | 77 | Mono.Posix \ | ||
295 | 78 | $(GLIB_SHARP_20_LIBS) | ||
296 | 79 | |||
297 | 80 | DLL_REFERENCES = \ | ||
298 | 81 | /usr/lib/tomboy/Tomboy.exe \ | ||
299 | 82 | Zeitgeist.dll | ||
300 | 83 | |||
301 | 84 | CLEANFILES = $(PROGRAMFILES) $(LINUX_PKGCONFIG) | ||
302 | 85 | |||
303 | 86 | include $(top_srcdir)/Makefile.include | ||
304 | 87 | |||
305 | 88 | ZEITGEIST_DLL = $(BUILD_DIR)/Zeitgeist.dll | ||
306 | 89 | TOMBOY_ZEITGEIST_PC = $(BUILD_DIR)/tomboy.zeitgeist.pc | ||
307 | 90 | |||
308 | 91 | $(eval $(call emit-deploy-target,ZEITGEIST_DLL)) | ||
309 | 92 | $(eval $(call emit-deploy-wrapper,TOMBOY_ZEITGEIST_PC,tomboy.zeitgeist.pc)) | ||
310 | 93 | |||
311 | 94 | |||
312 | 95 | $(eval $(call emit_resgen_targets)) | ||
313 | 96 | $(build_xamlg_list): %.xaml.g.cs: %.xaml | ||
314 | 97 | xamlg '$<' | ||
315 | 98 | |||
316 | 99 | $(ASSEMBLY_MDB): $(ASSEMBLY) | ||
317 | 100 | |||
318 | 101 | $(ASSEMBLY): $(build_sources) $(build_resources) $(build_datafiles) $(DLL_REFERENCES) $(PROJECT_REFERENCES) $(build_xamlg_list) $(build_satellite_assembly_list) | ||
319 | 102 | mkdir -p $(shell dirname $(ASSEMBLY)) | ||
320 | 103 | $(ASSEMBLY_COMPILER_COMMAND) $(ASSEMBLY_COMPILER_FLAGS) -out:$(ASSEMBLY) -target:$(COMPILE_TARGET) $(build_sources_embed) $(build_resources_embed) $(build_references_ref) | ||
321 | 0 | 104 | ||
322 | === added file 'tomboy/NoteHandler.cs' | |||
323 | --- tomboy/NoteHandler.cs 1970-01-01 00:00:00 +0000 | |||
324 | +++ tomboy/NoteHandler.cs 2010-09-19 19:01:06 +0000 | |||
325 | @@ -0,0 +1,69 @@ | |||
326 | 1 | using System; | ||
327 | 2 | using Zeitgeist.Datamodel; | ||
328 | 3 | using System.Collections.Generic; | ||
329 | 4 | |||
330 | 5 | namespace Tomboy.Zeitgeist | ||
331 | 6 | { | ||
332 | 7 | public class NoteHandler | ||
333 | 8 | { | ||
334 | 9 | public NoteHandler(Note note) | ||
335 | 10 | { | ||
336 | 11 | // Check if the Note has already been processes. | ||
337 | 12 | // Whent he note is being processed, event handlers are attached to | ||
338 | 13 | if (handledNotes.Contains(note) == false) | ||
339 | 14 | { | ||
340 | 15 | this._note = note; | ||
341 | 16 | |||
342 | 17 | note.Opened += HandleNoteOpened; | ||
343 | 18 | if (note.HasWindow) | ||
344 | 19 | { | ||
345 | 20 | HandleNoteOpened(); | ||
346 | 21 | } | ||
347 | 22 | } | ||
348 | 23 | } | ||
349 | 24 | |||
350 | 25 | void HandleNoteOpened (object sender, EventArgs e) | ||
351 | 26 | { | ||
352 | 27 | HandleNoteOpened(); | ||
353 | 28 | } | ||
354 | 29 | |||
355 | 30 | void HandleNoteOpened() | ||
356 | 31 | { | ||
357 | 32 | this._note.Window.Hidden += HandleNoteWindowHidden; | ||
358 | 33 | this._note.Window.Shown += HandleNoteWindowShown; | ||
359 | 34 | this._note.Renamed += HandleNoteRenamed; | ||
360 | 35 | if (this._note.Window.Visible) | ||
361 | 36 | { | ||
362 | 37 | HandleNoteWindowShown(); | ||
363 | 38 | } | ||
364 | 39 | } | ||
365 | 40 | |||
366 | 41 | void HandleNoteRenamed (Note sender, string old_title) | ||
367 | 42 | { | ||
368 | 43 | Console.WriteLine("Zg#: Renamed: " + this._note.Title); | ||
369 | 44 | ZeitgeistHandler.SendEvent(sender, Interpretation.Instance.EventInterpretation.ModifyEvent); | ||
370 | 45 | } | ||
371 | 46 | |||
372 | 47 | void HandleNoteWindowShown (object sender, EventArgs e) | ||
373 | 48 | { | ||
374 | 49 | HandleNoteWindowShown(); | ||
375 | 50 | } | ||
376 | 51 | |||
377 | 52 | void HandleNoteWindowShown () | ||
378 | 53 | { | ||
379 | 54 | Console.WriteLine("Zg#: Note window opened: " + this._note.Title); | ||
380 | 55 | ZeitgeistHandler.SendEvent(this._note, Interpretation.Instance.EventInterpretation.AccessEvent); | ||
381 | 56 | } | ||
382 | 57 | |||
383 | 58 | void HandleNoteWindowHidden (object sender, EventArgs e) | ||
384 | 59 | { | ||
385 | 60 | Console.WriteLine("Zg#: Note window closed: " + this._note.Title); | ||
386 | 61 | ZeitgeistHandler.SendEvent(this._note, Interpretation.Instance.EventInterpretation.LeaveEvent); | ||
387 | 62 | } | ||
388 | 63 | |||
389 | 64 | private Note _note; | ||
390 | 65 | |||
391 | 66 | private static List<Note> handledNotes = new List<Note>(); | ||
392 | 67 | } | ||
393 | 68 | } | ||
394 | 69 | |||
395 | 0 | 70 | ||
396 | === added file 'tomboy/Tomboy.Zeitgeist.csproj' | |||
397 | --- tomboy/Tomboy.Zeitgeist.csproj 1970-01-01 00:00:00 +0000 | |||
398 | +++ tomboy/Tomboy.Zeitgeist.csproj 2010-09-19 19:01:06 +0000 | |||
399 | @@ -0,0 +1,65 @@ | |||
400 | 1 | <?xml version="1.0" encoding="utf-8"?> | ||
401 | 2 | <Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> | ||
402 | 3 | <PropertyGroup> | ||
403 | 4 | <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration> | ||
404 | 5 | <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform> | ||
405 | 6 | <ProductVersion>9.0.21022</ProductVersion> | ||
406 | 7 | <SchemaVersion>2.0</SchemaVersion> | ||
407 | 8 | <ProjectGuid>{4DC09956-B20D-4ECA-8ACD-17E7609BAE41}</ProjectGuid> | ||
408 | 9 | <OutputType>Library</OutputType> | ||
409 | 10 | <RootNamespace>Tomboy.Zeitgeist</RootNamespace> | ||
410 | 11 | <AssemblyName>Tomboy.Zeitgeist</AssemblyName> | ||
411 | 12 | </PropertyGroup> | ||
412 | 13 | <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> | ||
413 | 14 | <DebugSymbols>true</DebugSymbols> | ||
414 | 15 | <DebugType>full</DebugType> | ||
415 | 16 | <Optimize>false</Optimize> | ||
416 | 17 | <OutputPath>bin\Debug</OutputPath> | ||
417 | 18 | <DefineConstants>DEBUG</DefineConstants> | ||
418 | 19 | <ErrorReport>prompt</ErrorReport> | ||
419 | 20 | <WarningLevel>4</WarningLevel> | ||
420 | 21 | <ConsolePause>false</ConsolePause> | ||
421 | 22 | </PropertyGroup> | ||
422 | 23 | <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' "> | ||
423 | 24 | <DebugType>none</DebugType> | ||
424 | 25 | <Optimize>false</Optimize> | ||
425 | 26 | <OutputPath>bin\Release</OutputPath> | ||
426 | 27 | <ErrorReport>prompt</ErrorReport> | ||
427 | 28 | <WarningLevel>4</WarningLevel> | ||
428 | 29 | <ConsolePause>false</ConsolePause> | ||
429 | 30 | </PropertyGroup> | ||
430 | 31 | <ItemGroup> | ||
431 | 32 | <Reference Include="System" /> | ||
432 | 33 | <Reference Include="Tomboy, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null"> | ||
433 | 34 | <SpecificVersion>False</SpecificVersion> | ||
434 | 35 | <HintPath>\usr\lib\tomboy\Tomboy.exe</HintPath> | ||
435 | 36 | <Private>False</Private> | ||
436 | 37 | </Reference> | ||
437 | 38 | <Reference Include="gtk-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f"> | ||
438 | 39 | <Package>gtk-sharp-2.0</Package> | ||
439 | 40 | </Reference> | ||
440 | 41 | <Reference Include="Mono.Posix" /> | ||
441 | 42 | <Reference Include="glib-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f"> | ||
442 | 43 | <Package>glib-sharp-2.0</Package> | ||
443 | 44 | </Reference> | ||
444 | 45 | <Reference Include="Zeitgeist, Version=1.0.3914.35475, Culture=neutral, PublicKeyToken=null"> | ||
445 | 46 | <SpecificVersion>False</SpecificVersion> | ||
446 | 47 | <HintPath>Zeitgeist.dll</HintPath> | ||
447 | 48 | </Reference> | ||
448 | 49 | </ItemGroup> | ||
449 | 50 | <ItemGroup> | ||
450 | 51 | <Compile Include="AssemblyInfo.cs" /> | ||
451 | 52 | <Compile Include="ZeitgeistAddin.cs" /> | ||
452 | 53 | <Compile Include="NoteHandler.cs" /> | ||
453 | 54 | <Compile Include="Zeitgeist.cs" /> | ||
454 | 55 | </ItemGroup> | ||
455 | 56 | <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" /> | ||
456 | 57 | <ItemGroup> | ||
457 | 58 | <EmbeddedResource Include="Zeitgeist.addin.xml" /> | ||
458 | 59 | </ItemGroup> | ||
459 | 60 | <ProjectExtensions> | ||
460 | 61 | <MonoDevelop> | ||
461 | 62 | <Properties InternalTargetFrameworkVersion="3.5" /> | ||
462 | 63 | </MonoDevelop> | ||
463 | 64 | </ProjectExtensions> | ||
464 | 65 | </Project> | ||
465 | 0 | 66 | ||
466 | === added file 'tomboy/Tomboy.Zeitgeist.sln' | |||
467 | --- tomboy/Tomboy.Zeitgeist.sln 1970-01-01 00:00:00 +0000 | |||
468 | +++ tomboy/Tomboy.Zeitgeist.sln 2010-09-19 19:01:06 +0000 | |||
469 | @@ -0,0 +1,20 @@ | |||
470 | 1 | | ||
471 | 2 | Microsoft Visual Studio Solution File, Format Version 9.00 | ||
472 | 3 | # Visual Studio 2005 | ||
473 | 4 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Tomboy.Zeitgeist", "Tomboy.Zeitgeist.csproj", "{2591D85F-7B39-486E-8260-D9022DE8BDE6}" | ||
474 | 5 | EndProject | ||
475 | 6 | Global | ||
476 | 7 | GlobalSection(SolutionConfigurationPlatforms) = preSolution | ||
477 | 8 | Debug|Any CPU = Debug|Any CPU | ||
478 | 9 | Release|Any CPU = Release|Any CPU | ||
479 | 10 | EndGlobalSection | ||
480 | 11 | GlobalSection(ProjectConfigurationPlatforms) = postSolution | ||
481 | 12 | {2591D85F-7B39-486E-8260-D9022DE8BDE6}.Debug|Any CPU.ActiveCfg = Debug|Any CPU | ||
482 | 13 | {2591D85F-7B39-486E-8260-D9022DE8BDE6}.Debug|Any CPU.Build.0 = Debug|Any CPU | ||
483 | 14 | {2591D85F-7B39-486E-8260-D9022DE8BDE6}.Release|Any CPU.ActiveCfg = Release|Any CPU | ||
484 | 15 | {2591D85F-7B39-486E-8260-D9022DE8BDE6}.Release|Any CPU.Build.0 = Release|Any CPU | ||
485 | 16 | EndGlobalSection | ||
486 | 17 | GlobalSection(MonoDevelopProperties) = preSolution | ||
487 | 18 | StartupItem = Tomboy.Zeitgeist.csproj | ||
488 | 19 | EndGlobalSection | ||
489 | 20 | EndGlobal | ||
490 | 0 | 21 | ||
491 | === modified file 'tomboy/Zeitgeist.addin.xml' | |||
492 | --- tomboy/Zeitgeist.addin.xml 2010-08-16 11:07:09 +0000 | |||
493 | +++ tomboy/Zeitgeist.addin.xml 2010-09-19 19:01:06 +0000 | |||
494 | @@ -1,14 +1,14 @@ | |||
495 | 1 | <Addin id="Zeitgeist" | 1 | <Addin id="Zeitgeist" |
496 | 2 | namespace="Tomboy" | 2 | namespace="Tomboy" |
497 | 3 | name="Zeitgeist Integration" | 3 | name="Zeitgeist Integration" |
499 | 4 | author="Laszlo Pandy laszlok2@gmail.com" | 4 | author="Manish Sinha" |
500 | 5 | description="Logs usage data to Zeitgeist." | 5 | description="Logs usage data to Zeitgeist." |
501 | 6 | category="Desktop Integration" | 6 | category="Desktop Integration" |
502 | 7 | defaultEnabled="true" | 7 | defaultEnabled="true" |
503 | 8 | version="0.1"> | 8 | version="0.1"> |
504 | 9 | 9 | ||
505 | 10 | <Runtime> | 10 | <Runtime> |
507 | 11 | <Import assembly="Zeitgeist.dll" /> | 11 | <Import assembly="Tomboy.Zeitgeist.dll" /> |
508 | 12 | </Runtime> | 12 | </Runtime> |
509 | 13 | 13 | ||
510 | 14 | <Dependencies> | 14 | <Dependencies> |
511 | 15 | 15 | ||
512 | === added file 'tomboy/Zeitgeist.cs' | |||
513 | --- tomboy/Zeitgeist.cs 1970-01-01 00:00:00 +0000 | |||
514 | +++ tomboy/Zeitgeist.cs 2010-09-19 19:01:06 +0000 | |||
515 | @@ -0,0 +1,83 @@ | |||
516 | 1 | using System; | ||
517 | 2 | using Zeitgeist.Datamodel; | ||
518 | 3 | using Zeitgeist; | ||
519 | 4 | using System.Collections.Generic; | ||
520 | 5 | using Tomboy; | ||
521 | 6 | |||
522 | 7 | namespace Tomboy.Zeitgeist | ||
523 | 8 | { | ||
524 | 9 | public class ZeitgeistHandler | ||
525 | 10 | { | ||
526 | 11 | public static bool SendEvent(Note note, KeyValuePair<string,string> eventInterpretation) | ||
527 | 12 | { | ||
528 | 13 | KeyValuePair<string,string> eventManifestation = Manifestation.Instance.EventManifestation.UserActivity; | ||
529 | 14 | |||
530 | 15 | KeyValuePair<string,string> subjectInterpretation = Interpretation.Instance.Document.Document; | ||
531 | 16 | KeyValuePair<string,string> subjectManifestation = Manifestation.Instance.FileDataObject.FileDataObject; | ||
532 | 17 | |||
533 | 18 | Event ev = EventCreator.CreateEvent(note, eventInterpretation, eventManifestation, subjectInterpretation, subjectManifestation); | ||
534 | 19 | |||
535 | 20 | |||
536 | 21 | try | ||
537 | 22 | { | ||
538 | 23 | List<Event> listOfEvents = new List<Event>(); | ||
539 | 24 | listOfEvents.Add(ev); | ||
540 | 25 | |||
541 | 26 | GLib.Idle.Add(delegate() | ||
542 | 27 | { | ||
543 | 28 | SendEvent(listOfEvents); | ||
544 | 29 | return false; | ||
545 | 30 | }); | ||
546 | 31 | |||
547 | 32 | Console.WriteLine(string.Format("Operation {0} successful", ev.Interpretation.Key)); | ||
548 | 33 | return true; | ||
549 | 34 | } | ||
550 | 35 | catch(Exception e) | ||
551 | 36 | { | ||
552 | 37 | Console.WriteLine(e.StackTrace); | ||
553 | 38 | |||
554 | 39 | return false; | ||
555 | 40 | } | ||
556 | 41 | } | ||
557 | 42 | |||
558 | 43 | private static void SendEvent(List<Event> e) | ||
559 | 44 | { | ||
560 | 45 | LogClient client = new LogClient(); | ||
561 | 46 | client.InsertEvents(e); | ||
562 | 47 | } | ||
563 | 48 | } | ||
564 | 49 | |||
565 | 50 | public class EventCreator | ||
566 | 51 | { | ||
567 | 52 | public static Event CreateEvent(Note note, | ||
568 | 53 | KeyValuePair<string,string> eventInterpretation, | ||
569 | 54 | KeyValuePair<string,string> eventManifestation, | ||
570 | 55 | KeyValuePair<string,string> subjectInterpretation, | ||
571 | 56 | KeyValuePair<string,string> subjectManifestation) | ||
572 | 57 | { | ||
573 | 58 | Event ev = new Event(); | ||
574 | 59 | |||
575 | 60 | |||
576 | 61 | ev.Id = 0; | ||
577 | 62 | ev.Timestamp = DateTime.Now; | ||
578 | 63 | ev.Interpretation = eventInterpretation; | ||
579 | 64 | ev.Manifestation = eventManifestation; | ||
580 | 65 | ev.Actor = ZeitgeistAddin.TomboyUri; | ||
581 | 66 | |||
582 | 67 | Subject sub = new Subject(); | ||
583 | 68 | |||
584 | 69 | sub.Uri = note.Uri; | ||
585 | 70 | sub.Interpretation = subjectInterpretation; | ||
586 | 71 | sub.Manifestation = subjectManifestation; | ||
587 | 72 | sub.Origin = string.Empty; | ||
588 | 73 | sub.MimeType = ZeitgeistAddin.NoteMimetype; | ||
589 | 74 | sub.Text = note.Title; | ||
590 | 75 | sub.Storage = string.Empty; | ||
591 | 76 | |||
592 | 77 | ev.Subjects.Add(sub); | ||
593 | 78 | |||
594 | 79 | return ev; | ||
595 | 80 | } | ||
596 | 81 | } | ||
597 | 82 | } | ||
598 | 83 | |||
599 | 0 | 84 | ||
600 | === removed file 'tomboy/Zeitgeist.cs' | |||
601 | --- tomboy/Zeitgeist.cs 2010-08-19 10:33:11 +0000 | |||
602 | +++ tomboy/Zeitgeist.cs 1970-01-01 00:00:00 +0000 | |||
603 | @@ -1,200 +0,0 @@ | |||
604 | 1 | |||
605 | 2 | using System; | ||
606 | 3 | using System.Collections.Generic; | ||
607 | 4 | using Tomboy; | ||
608 | 5 | using NDesk.DBus; | ||
609 | 6 | using Gtk; | ||
610 | 7 | using GLib; | ||
611 | 8 | using Mono.Unix.Native; | ||
612 | 9 | |||
613 | 10 | namespace Tomboy.Zeitgeist | ||
614 | 11 | { | ||
615 | 12 | class NoteHandler | ||
616 | 13 | { | ||
617 | 14 | private static List<string> handled_notes = new List<string>(); | ||
618 | 15 | private Note note; | ||
619 | 16 | |||
620 | 17 | public NoteHandler(Note note) { | ||
621 | 18 | if (handled_notes.Contains(note.Id) == false) { | ||
622 | 19 | this.note = note; | ||
623 | 20 | note.Opened += HandleNoteOpened; | ||
624 | 21 | if (note.HasWindow) { | ||
625 | 22 | HandleNoteOpened(); | ||
626 | 23 | } | ||
627 | 24 | } | ||
628 | 25 | } | ||
629 | 26 | |||
630 | 27 | void HandleNoteOpened (object sender, EventArgs e) { | ||
631 | 28 | HandleNoteOpened(); | ||
632 | 29 | } | ||
633 | 30 | void HandleNoteOpened() { | ||
634 | 31 | note.Window.Hidden += HandleNoteWindowHidden; | ||
635 | 32 | note.Window.Shown += HandleNoteWindowShown; | ||
636 | 33 | note.Renamed += HandleNoteRenamed; | ||
637 | 34 | if (note.Window.Visible) { | ||
638 | 35 | HandleNoteWindowShown(); | ||
639 | 36 | } | ||
640 | 37 | } | ||
641 | 38 | |||
642 | 39 | void HandleNoteRenamed (Note sender, string old_title) | ||
643 | 40 | { | ||
644 | 41 | Console.WriteLine("Zg: Renamed: " + note.Title); | ||
645 | 42 | ZeitgeistDbus.SendToZeitgeist(note, ZeitgeistDbus.EventInterpretation.ModifyEvent); | ||
646 | 43 | } | ||
647 | 44 | |||
648 | 45 | void HandleNoteWindowShown (object sender, EventArgs e) { | ||
649 | 46 | HandleNoteWindowShown(); | ||
650 | 47 | } | ||
651 | 48 | void HandleNoteWindowShown () | ||
652 | 49 | { | ||
653 | 50 | Console.WriteLine("Zg: Note window opened: " + note.Title); | ||
654 | 51 | ZeitgeistDbus.SendToZeitgeist(note, ZeitgeistDbus.EventInterpretation.OpenEvent); | ||
655 | 52 | } | ||
656 | 53 | |||
657 | 54 | void HandleNoteWindowHidden (object sender, EventArgs e) | ||
658 | 55 | { | ||
659 | 56 | Console.WriteLine("Zg: Note window closed: " + note.Title); | ||
660 | 57 | ZeitgeistDbus.SendToZeitgeist(note, ZeitgeistDbus.EventInterpretation.CloseEvent); | ||
661 | 58 | } | ||
662 | 59 | } | ||
663 | 60 | |||
664 | 61 | class ZeitgeistDbus | ||
665 | 62 | { | ||
666 | 63 | private static ILogger zeitgeist_proxy = | ||
667 | 64 | Bus.Session.GetObject<ILogger>("org.gnome.zeitgeist.Engine", | ||
668 | 65 | new ObjectPath("/org/gnome/zeitgeist/log/activity")); | ||
669 | 66 | |||
670 | 67 | public enum EventInterpretation { | ||
671 | 68 | OpenEvent, | ||
672 | 69 | CloseEvent, | ||
673 | 70 | CreateEvent, | ||
674 | 71 | ModifyEvent, | ||
675 | 72 | } | ||
676 | 73 | |||
677 | 74 | private static string GetEventInterpetation(EventInterpretation e) { | ||
678 | 75 | switch(e) { | ||
679 | 76 | case EventInterpretation.OpenEvent: | ||
680 | 77 | return "http://www.zeitgeist-project.com/ontologies/2010/01/27/zg#AccessEvent"; | ||
681 | 78 | case EventInterpretation.CloseEvent: | ||
682 | 79 | return "http://www.zeitgeist-project.com/ontologies/2010/01/27/zg#LeaveEvent"; | ||
683 | 80 | case EventInterpretation.CreateEvent: | ||
684 | 81 | return "http://www.zeitgeist-project.com/ontologies/2010/01/27/zg#CreateEvent"; | ||
685 | 82 | case EventInterpretation.ModifyEvent: | ||
686 | 83 | return "http://www.zeitgeist-project.com/ontologies/2010/01/27/zg#ModifyEvent"; | ||
687 | 84 | default: | ||
688 | 85 | return null; | ||
689 | 86 | } | ||
690 | 87 | } | ||
691 | 88 | |||
692 | 89 | public static void SendToZeitgeist(Note note, EventInterpretation ev_interp) { | ||
693 | 90 | if (zeitgeist_proxy == null) { | ||
694 | 91 | Console.WriteLine("Zg: cannot connect to zeitgeist, dbus proxy is null"); | ||
695 | 92 | return; | ||
696 | 93 | } | ||
697 | 94 | |||
698 | 95 | string ev_interp_string = GetEventInterpetation(ev_interp); | ||
699 | 96 | if (ev_interp_string == null) { | ||
700 | 97 | Console.WriteLine("Zg: unknown interpretation type: " + ev_interp.ToString()); | ||
701 | 98 | return; | ||
702 | 99 | } | ||
703 | 100 | |||
704 | 101 | Timeval t; | ||
705 | 102 | Syscall.gettimeofday(out t); | ||
706 | 103 | long millis_now = (t.tv_sec * 1000) + (t.tv_usec / 1000); | ||
707 | 104 | |||
708 | 105 | Event e = new Event(); | ||
709 | 106 | e.metadata = new string[5]; | ||
710 | 107 | e.metadata[0] = ""; //id (filled in by Zeitgeist) | ||
711 | 108 | e.metadata[1] = millis_now.ToString(); | ||
712 | 109 | e.metadata[2] = ev_interp_string; | ||
713 | 110 | e.metadata[3] = "http://www.zeitgeist-project.com/ontologies/2010/01/27/zg#UserActivity"; | ||
714 | 111 | e.metadata[4] = "application://tomboy.desktop"; | ||
715 | 112 | |||
716 | 113 | string[] subject = new string[7]; | ||
717 | 114 | subject[0] = note.Uri; | ||
718 | 115 | subject[1] = "http://www.semanticdesktop.org/ontologies/2007/03/22/nfo#Document"; | ||
719 | 116 | subject[2] = "http://www.semanticdesktop.org/ontologies/nfo#FileDataObject"; | ||
720 | 117 | subject[3] = ""; //origin | ||
721 | 118 | subject[4] = "application/x-tomboy"; //mimetype | ||
722 | 119 | subject[5] = note.Title; | ||
723 | 120 | subject[6] = ""; //storage id | ||
724 | 121 | |||
725 | 122 | e.subjects = new string[][] { subject }; | ||
726 | 123 | e.payload = new byte[0]; | ||
727 | 124 | |||
728 | 125 | GLib.Idle.Add(delegate() { | ||
729 | 126 | SendEvent(e); | ||
730 | 127 | return false; | ||
731 | 128 | }); | ||
732 | 129 | } | ||
733 | 130 | |||
734 | 131 | private static void SendEvent(Event e) { | ||
735 | 132 | int[] inserted; | ||
736 | 133 | try { | ||
737 | 134 | inserted = zeitgeist_proxy.InsertEvents(new Event[] { e }); | ||
738 | 135 | } catch (Exception ex) { | ||
739 | 136 | Console.WriteLine("Zg: insertion failed: " + ex.Message); | ||
740 | 137 | return; | ||
741 | 138 | } | ||
742 | 139 | |||
743 | 140 | if (inserted.Length > 0) { | ||
744 | 141 | Console.WriteLine("Zg: Inserted event: " + inserted[0]); | ||
745 | 142 | } | ||
746 | 143 | else { | ||
747 | 144 | Console.WriteLine("Zg: Insertion failed"); | ||
748 | 145 | } | ||
749 | 146 | return; | ||
750 | 147 | } | ||
751 | 148 | } | ||
752 | 149 | |||
753 | 150 | [NDesk.DBus.Interface ("org.gnome.zeitgeist.Log")] | ||
754 | 151 | interface ILogger { | ||
755 | 152 | int[] InsertEvents(Event[] events); | ||
756 | 153 | } | ||
757 | 154 | |||
758 | 155 | struct Event { | ||
759 | 156 | public string[] metadata; | ||
760 | 157 | public string[][] subjects; | ||
761 | 158 | public byte[] payload; | ||
762 | 159 | } | ||
763 | 160 | |||
764 | 161 | public class ZeitgeistAddin : ApplicationAddin | ||
765 | 162 | { | ||
766 | 163 | private bool _init = false; | ||
767 | 164 | public override bool Initialized { | ||
768 | 165 | get { return _init; } | ||
769 | 166 | } | ||
770 | 167 | |||
771 | 168 | public override | ||
772 | 169 | void Initialize() { | ||
773 | 170 | Console.WriteLine("Zg: init new"); | ||
774 | 171 | init_handlers(); | ||
775 | 172 | _init = true; | ||
776 | 173 | } | ||
777 | 174 | |||
778 | 175 | public override | ||
779 | 176 | void Shutdown() { | ||
780 | 177 | Console.WriteLine("Zg: shutdown"); | ||
781 | 178 | } | ||
782 | 179 | |||
783 | 180 | void HandleNoteAdded(object sender, Note new_note) { | ||
784 | 181 | Console.WriteLine("Zg: Note added: " + new_note.Title); | ||
785 | 182 | Console.WriteLine("\t" + new_note.Uri); | ||
786 | 183 | |||
787 | 184 | new NoteHandler(new_note); | ||
788 | 185 | ZeitgeistDbus.SendToZeitgeist(new_note, ZeitgeistDbus.EventInterpretation.CreateEvent); | ||
789 | 186 | } | ||
790 | 187 | |||
791 | 188 | public void init_handlers() { | ||
792 | 189 | foreach (Note note in Tomboy.DefaultNoteManager.Notes) { | ||
793 | 190 | new NoteHandler(note); | ||
794 | 191 | } | ||
795 | 192 | |||
796 | 193 | Tomboy.DefaultNoteManager.NoteAdded -= HandleNoteAdded; | ||
797 | 194 | Tomboy.DefaultNoteManager.NoteAdded += HandleNoteAdded; | ||
798 | 195 | } | ||
799 | 196 | } | ||
800 | 197 | |||
801 | 198 | |||
802 | 199 | |||
803 | 200 | } | ||
804 | 201 | 0 | ||
805 | === added file 'tomboy/Zeitgeist.dll' | |||
806 | 202 | Binary files tomboy/Zeitgeist.dll 1970-01-01 00:00:00 +0000 and tomboy/Zeitgeist.dll 2010-09-19 19:01:06 +0000 differ | 1 | Binary files tomboy/Zeitgeist.dll 1970-01-01 00:00:00 +0000 and tomboy/Zeitgeist.dll 2010-09-19 19:01:06 +0000 differ |
807 | === removed file 'tomboy/Zeitgeist.mdp' | |||
808 | --- tomboy/Zeitgeist.mdp 2010-08-16 10:57:40 +0000 | |||
809 | +++ tomboy/Zeitgeist.mdp 1970-01-01 00:00:00 +0000 | |||
810 | @@ -1,28 +0,0 @@ | |||
811 | 1 | <Project name="Zeitgeist" fileversion="2.0" DefaultNamespace="Zeitgeist" language="C#" targetFramework="2.0" ctype="DotNetProject"> | ||
812 | 2 | <Configurations active="Debug"> | ||
813 | 3 | <Configuration name="Debug" ctype="DotNetProjectConfiguration"> | ||
814 | 4 | <Output directory="bin/Debug" assembly="Zeitgeist" /> | ||
815 | 5 | <Build debugmode="True" target="Library" /> | ||
816 | 6 | <Execution consolepause="False" runwithwarnings="True" runtime="MsNet" /> | ||
817 | 7 | <CodeGeneration compiler="Mcs" warninglevel="4" optimize="False" unsafecodeallowed="False" generateoverflowchecks="False" definesymbols="DEBUG" generatexmldocumentation="False" ctype="CSharpCompilerParameters" /> | ||
818 | 8 | </Configuration> | ||
819 | 9 | <Configuration name="Release" ctype="DotNetProjectConfiguration"> | ||
820 | 10 | <Output directory="bin/Release" assembly="Zeitgeist" /> | ||
821 | 11 | <Build debugmode="False" target="Library" /> | ||
822 | 12 | <Execution consolepause="False" runwithwarnings="True" runtime="MsNet" /> | ||
823 | 13 | <CodeGeneration compiler="Mcs" warninglevel="4" optimize="False" unsafecodeallowed="False" generateoverflowchecks="False" generatexmldocumentation="False" ctype="CSharpCompilerParameters" /> | ||
824 | 14 | </Configuration> | ||
825 | 15 | </Configurations> | ||
826 | 16 | <Contents> | ||
827 | 17 | <File subtype="Code" buildaction="Compile" name="Zeitgeist.cs" /> | ||
828 | 18 | <File subtype="Code" buildaction="EmbedAsResource" name="Zeitgeist.addin.xml" /> | ||
829 | 19 | </Contents> | ||
830 | 20 | <References> | ||
831 | 21 | <ProjectReference type="Gac" localcopy="True" refto="System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> | ||
832 | 22 | <ProjectReference type="Gac" localcopy="True" refto="glib-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f" /> | ||
833 | 23 | <ProjectReference type="Gac" localcopy="True" refto="NDesk.DBus, Version=1.0.0.0, Culture=neutral, PublicKeyToken=f6716e4f9b2ed099" /> | ||
834 | 24 | <ProjectReference type="Gac" localcopy="True" refto="gtk-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f" /> | ||
835 | 25 | <ProjectReference type="Gac" localcopy="True" refto="Mono.Posix, Version=2.0.0.0, Culture=neutral, PublicKeyToken=0738eb9f132ed756" /> | ||
836 | 26 | <ProjectReference type="Assembly" localcopy="True" specificVersion="False" refto="/usr/lib/tomboy/Tomboy.exe" /> | ||
837 | 27 | </References> | ||
838 | 28 | </Project> | ||
839 | 29 | 0 | ||
840 | === added file 'tomboy/ZeitgeistAddin.cs' | |||
841 | --- tomboy/ZeitgeistAddin.cs 1970-01-01 00:00:00 +0000 | |||
842 | +++ tomboy/ZeitgeistAddin.cs 2010-09-19 19:01:06 +0000 | |||
843 | @@ -0,0 +1,90 @@ | |||
844 | 1 | using System; | ||
845 | 2 | using Tomboy; | ||
846 | 3 | using System.Collections.Generic; | ||
847 | 4 | using System.IO; | ||
848 | 5 | using Zeitgeist.Datamodel; | ||
849 | 6 | |||
850 | 7 | namespace Tomboy.Zeitgeist | ||
851 | 8 | { | ||
852 | 9 | public class ZeitgeistAddin : ApplicationAddin | ||
853 | 10 | { | ||
854 | 11 | public ZeitgeistAddin () | ||
855 | 12 | { | ||
856 | 13 | notesList = new List<NoteHandler>(); | ||
857 | 14 | } | ||
858 | 15 | |||
859 | 16 | #region Overridden methods | ||
860 | 17 | |||
861 | 18 | public override bool Initialized | ||
862 | 19 | { | ||
863 | 20 | get | ||
864 | 21 | { | ||
865 | 22 | return _init; | ||
866 | 23 | } | ||
867 | 24 | } | ||
868 | 25 | |||
869 | 26 | public override void Initialize() | ||
870 | 27 | { | ||
871 | 28 | Console.WriteLine("Zg#: init new"); | ||
872 | 29 | |||
873 | 30 | // Initialize the handlers for hooking into Tomboy | ||
874 | 31 | InitHandlers(); | ||
875 | 32 | |||
876 | 33 | _init = true; | ||
877 | 34 | } | ||
878 | 35 | |||
879 | 36 | public override void Shutdown() | ||
880 | 37 | { | ||
881 | 38 | Console.WriteLine("Zg#: shutdown"); | ||
882 | 39 | } | ||
883 | 40 | |||
884 | 41 | #endregion | ||
885 | 42 | |||
886 | 43 | public void InitHandlers() | ||
887 | 44 | { | ||
888 | 45 | // For every note present in the store | ||
889 | 46 | |||
890 | 47 | foreach (Note note in Tomboy.DefaultNoteManager.Notes) | ||
891 | 48 | { | ||
892 | 49 | notesList.Add(new NoteHandler(note)); | ||
893 | 50 | } | ||
894 | 51 | |||
895 | 52 | Tomboy.DefaultNoteManager.NoteAdded -= HandleNoteAdded; | ||
896 | 53 | Tomboy.DefaultNoteManager.NoteAdded += HandleNoteAdded; | ||
897 | 54 | |||
898 | 55 | Tomboy.DefaultNoteManager.NoteDeleted -= HandleNoteDeleted; | ||
899 | 56 | Tomboy.DefaultNoteManager.NoteDeleted += HandleNoteDeleted; | ||
900 | 57 | } | ||
901 | 58 | |||
902 | 59 | void HandleNoteAdded(object sender, Note new_note) | ||
903 | 60 | { | ||
904 | 61 | Console.WriteLine("Zg#: Note added: " + new_note.Title); | ||
905 | 62 | Console.WriteLine("\t" + new_note.Uri); | ||
906 | 63 | |||
907 | 64 | notesList.Add(new NoteHandler(new_note)); | ||
908 | 65 | |||
909 | 66 | ZeitgeistHandler.SendEvent(new_note, Interpretation.Instance.EventInterpretation.CreateEvent); | ||
910 | 67 | } | ||
911 | 68 | |||
912 | 69 | void HandleNoteDeleted(object sender, Note new_note) | ||
913 | 70 | { | ||
914 | 71 | Console.WriteLine("Zg#: Note deleted: " + new_note.Title); | ||
915 | 72 | Console.WriteLine("\t" + new_note.Uri); | ||
916 | 73 | |||
917 | 74 | ZeitgeistHandler.SendEvent(new_note, Interpretation.Instance.EventInterpretation.DeleteEvent); | ||
918 | 75 | } | ||
919 | 76 | |||
920 | 77 | List<NoteHandler> notesList; | ||
921 | 78 | |||
922 | 79 | private bool _init = false; | ||
923 | 80 | |||
924 | 81 | #region Public Constants | ||
925 | 82 | |||
926 | 83 | public const string TomboyUri = "application://tomboy.desktop"; | ||
927 | 84 | |||
928 | 85 | public const string NoteMimetype = "application/x-tomboy"; | ||
929 | 86 | |||
930 | 87 | #endregion | ||
931 | 88 | } | ||
932 | 89 | } | ||
933 | 90 | |||
934 | 0 | 91 | ||
935 | === removed file 'tomboy/install.sh' | |||
936 | --- tomboy/install.sh 2010-02-03 16:06:55 +0000 | |||
937 | +++ tomboy/install.sh 1970-01-01 00:00:00 +0000 | |||
938 | @@ -1,13 +0,0 @@ | |||
939 | 1 | #!/bin/sh | ||
940 | 2 | |||
941 | 3 | mkdir -p ~/.config/tomboy/addins/ | ||
942 | 4 | |||
943 | 5 | # Please install monodevelop to get mdtool. | ||
944 | 6 | # Please edit Zeitgeist.mdp and change the local path of Tomboy.exe | ||
945 | 7 | # to the correct one for your environment (so it can link to the | ||
946 | 8 | # correct version of Tomboy). | ||
947 | 9 | mdtool build Zeitgeist.mdp | ||
948 | 10 | |||
949 | 11 | cp bin/Debug/Zeitgeist.dll ~/.config/tomboy/addins/Zeitgeist.dll | ||
950 | 12 | |||
951 | 13 | |||
952 | 14 | 0 | ||
953 | === added file 'tomboy/tomboy.zeitgeist.pc' | |||
954 | --- tomboy/tomboy.zeitgeist.pc 1970-01-01 00:00:00 +0000 | |||
955 | +++ tomboy/tomboy.zeitgeist.pc 2010-09-19 19:01:06 +0000 | |||
956 | @@ -0,0 +1,6 @@ | |||
957 | 1 | Name: Tomboy.Zeitgeist | ||
958 | 2 | Description: Tomboy.Zeitgeist | ||
959 | 3 | Version: 0.1 | ||
960 | 4 | |||
961 | 5 | Requires: | ||
962 | 6 | Libs: -r:@expanded_libdir@/@PACKAGE@/Tomboy.Zeitgeist.dll |
From a quick look (I'm not using Tomboy): //tomboy. desktop
- 'TomboyUri' should be just application:
- please get rid of the install.sh script, everything is now done using Makefiles
- I really don't like the bundled dll library, isn't there another way to check for it?