| 113 | return self.remote_changed() |
| 114 | |
| 115 | def upload(self): |
| 116 | |
| 117 | self.prepare() |
| 118 | |
| 119 | # Plugins may actually update those values afterwards |
| 120 | self.cache_control = self.MAX_CACHE_EXPIRATION if self.is_fingerprinted else self.DEFAULT_CACHE_EXPIRATION |
| 121 | self.content_encoding = 'gzip' if self.is_compressed else None |
| 122 | self.content_length = len(self.payload()) |
| 123 | |
| 124 | self.engine.site.plugin_manager.preDeployFile(self) |
| 125 | |
| 126 | remote_changed = self.remote_changed() |
| 127 | |
| 128 | if remote_changed: |
| 129 | self.do_upload() |
| 130 | |
| 131 | self.total_bytes_uploaded = self.total_bytes |
| 132 | |
| 133 | op1 = '+' if remote_changed else '-' |
| 134 | op2 = ' (%s compressed)' % (fileSize(len(self.payload()))) if self.is_compressed else '' |
| 135 | |
| 136 | # logger.warning("deploy.progress %s", self.engine.progress()) |
| 137 | |
| 138 | ipc.signal("deploy.progress", { |
| 139 | "progress": self.engine.progress(), |
| 140 | "fileName": self.path |
| 141 | }) |
| 142 | |
| 143 | logger.info('%s %s - %s%s' % (op1, self.path, fileSize(len(self.data())), op2)) |
| 144 | |
| 145 | return {'changed': remote_changed, 'size': len(self.payload())} |
| 146 | |
| 147 | def __repr__(self): |
| 148 | return '<File: {0}>'.format(self.path) |